├── .gitignore ├── LICENSE ├── README.md ├── app.js ├── app ├── models │ ├── authentic.model.js │ └── user-model.js ├── routes │ ├── authentic.route.js │ └── user.route.js ├── schema │ ├── loginValidationSchema.json │ └── userValidationSchema.json └── services │ ├── authentic.service.js │ └── user.service.js ├── common ├── error-code.js ├── error-methods.js ├── iValidator.js └── mailer.js ├── config ├── api-config.js ├── database.js ├── db-function.js └── secureRoute.js ├── documents ├── sql-script │ └── script_v1.sql └── swagger │ ├── swagger_v1.html │ └── swagger_v1.json ├── loadtest ├── hello.csv ├── hello.yml └── hellocsv.yml ├── package-lock.json ├── package.json ├── public └── index.html └── web.config /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | 8 | # Runtime data 9 | pids 10 | *.pid 11 | *.seed 12 | *.pid.lock 13 | 14 | # Directory for instrumented libs generated by jscoverage/JSCover 15 | lib-cov 16 | 17 | # Coverage directory used by tools like istanbul 18 | coverage 19 | 20 | # nyc test coverage 21 | .nyc_output 22 | 23 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 24 | .grunt 25 | 26 | # Bower dependency directory (https://bower.io/) 27 | bower_components 28 | 29 | # node-waf configuration 30 | .lock-wscript 31 | 32 | # Compiled binary addons (http://nodejs.org/api/addons.html) 33 | build/Release 34 | 35 | # Dependency directories 36 | node_modules/ 37 | jspm_packages/ 38 | 39 | # Typescript v1 declaration files 40 | typings/ 41 | 42 | # Optional npm cache directory 43 | .npm 44 | 45 | # Optional eslint cache 46 | .eslintcache 47 | 48 | # Optional REPL history 49 | .node_repl_history 50 | 51 | # Output of 'npm pack' 52 | *.tgz 53 | 54 | # Yarn Integrity file 55 | .yarn-integrity 56 | 57 | # dotenv environment variables file 58 | .env 59 | 60 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 yug95 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 | # Node with MySQL BoilerPlate/Framework 2 | 3 | A simple and structured way boilerplate for Node with MySQL, equipped with MVC layer model with basic validation of schema and common error handler, authentication and easily pluggable code base. 4 | 5 | This Boilerplate have a basic CRUD operation with MySQL, authetication of API endpoint with JWT Token and Validation of request and response of each route. It contained a documentation folder which contain swagger documentation easy for front-end developer to use and understand. It contained Pm2 which helps to restart, reload and monitor application in production, provides zero downtime availability. It has Nodemailer which will send email. It has bcrypt module which will encrypt password and make it more secure. It contain Artillery for load testing. 6 | 7 | # PreRequisite 8 | 9 | * xampp/lampp/wampp application to run MySQL database and Apache server [Download from here](https://www.apachefriends.org/download.html). 10 | * Download Node js and install in your operating system. [Download from here](https://nodejs.org/en/download/) 11 | * Postman a desktop app or you can use it [chrome extension](https://chrome.google.com/webstore/category/extensions) for API testing.[Download from here](https://www.getpostman.com/apps) 12 | 13 | # Used Packages 14 | 15 | ### 1. MYSQL 16 | ``` 17 | npm install mysql 18 | ``` 19 | * Used to get mysql function and modules to perform DB operation [know more about package](https://www.npmjs.com/package/mysql) 20 | * To Know more about MySQL built in functions [check here](https://www.github.com/mysqljs/mysql) 21 | 22 | --- 23 | 24 | ### 2. Express 25 | ``` 26 | npm install express 27 | ``` 28 | * Platform it built over it [know more about express](https://www.npmjs.com/package/express) 29 | * To Know more about Express built in functions [check here](http://expressjs.com/en/starter/installing.html) 30 | 31 | --- 32 | 33 | ### 3. Ajv 34 | ``` 35 | npm install ajv 36 | ``` 37 | * ajv used for validation of schema [know more about ajv](https://www.npmjs.com/package/ajv) 38 | * To Know more about ajv built in functions [check here](https://www.npmjs.com/package/ajv) 39 | 40 | --- 41 | 42 | ### 4. JWT 43 | ``` 44 | npm install jsonwebtoken 45 | ``` 46 | * jsonwebtoken is used for authentication of api through Token [know more about jwt](https://www.npmjs.com/package/jsonwebtoken) 47 | * To Know more about jwt built in functions [check here](https://jwt.io/) 48 | 49 | --- 50 | 51 | ### 5. Nodemon 52 | ``` 53 | npm install nodemon 54 | ``` 55 | * Nodemon will watch the files in the directory and if file changes automatically restart application [know more about nodemon](https://www.npmjs.com/package/nodemon) 56 | * To Know more about nodemon [check here](https://nodemon.io) 57 | 58 | --- 59 | 60 | ### 6. pm2 61 | ``` 62 | npm install pm2 63 | ``` 64 | * pm2 will watch, restart and reload application if any crashes happen, it provide cluster mode as well as zero downtime failure. [know more about pm2](https://www.npmjs.com/package/pm2) 65 | * To Know more about pm2 [check here](http://pm2.keymetrics.io/docs/usage/quick-start/) 66 | 67 | --- 68 | 69 | ### 7. nodemailer 70 | ``` 71 | npm install nodemailer 72 | ``` 73 | * nodemailer will send mail to given mail Id as for now i used for sending if any error comes.[know more about nodemailer](https://www.npmjs.com/package/nodemailer) 74 | * To Know more about nodemailer [check here](https://nodemailer.com/about/) 75 | 76 | --- 77 | 78 | ### 8. artillery 79 | ``` 80 | npm install artillery 81 | ``` 82 | * artillery will perform load testing and gives logs, how sustainable your Api to perform number of request in per second .[know more about artillery](https://www.npmjs.com/package/artillery) 83 | * To Know more about artillery [check here](https://artillery.io/) 84 | 85 | --- 86 | 87 | ### 9. bcrypt 88 | ``` 89 | npm install bcrypt 90 | ``` 91 | * bcrypt will encrypt your password throughing hashing so your password won't store as plain text .[know more about bcrypt](https://www.npmjs.com/package/bcrypt) 92 | * To Know more about nodemailer [check here](https://www.npmjs.com/package/bcrypt) 93 | 94 | --- 95 | 96 | # Table Creation In DB 97 | 98 | 1. Create Table user with `id,name,age,state,country` columns. 99 | 2. you can try creating your table as well just need to change query and table name in model section. 100 | 101 | # Get Started 102 | 103 | 1. `$ git clone https://github.com/yug95/node-mysql.git` 104 | 2. `$ npm install` 105 | 3. Launch Enviornment: 106 | * `$ node app.js or nodemon app.js` 107 | 4. In Cluster mode with the help of pm2 [optional step]: 108 | * `$ pm2 start app.js or pm2 start app.js -i ` 109 | 5. Open in browser: 110 | * open `http://localhost:9890` 111 | 112 | 113 | 114 | # API Usage 115 | 116 | 1. signup route - `http://localhost:9890/api/signup` 117 | * pass json object contain username and password. 118 | 2. login route - `http://localhost:9890/api/login` 119 | * pass json object contain username and password. 120 | 3. other crud route are in secureApi - `localhost:9890/secureApi/user`. 121 | * In all GET, PUT, DELETE and POST request pass `token` in header which you get in login response. 122 | 123 | Example object for login request (body as JSON object) - 124 | 125 | ``` 126 | { 127 | "username":"test", 128 | "password":"testpass" 129 | } 130 | ``` 131 | For Other Crud request - 132 | 133 | ``` 134 | { 135 | "name":"username", 136 | "age:11, 137 | "state":"statename", 138 | "country":"countryname" 139 | } 140 | 141 | ``` 142 | Note: You have to pass `token` for each request as header which youi will get in login response. 143 | 144 | # Features 145 | 146 | * To perform basic operation all `Create`, `Fetch`, `Delete` and `Update` functionality. 147 | * Used Express framework to obtain required operations. 148 | * Used Express router to route endpoint path. 149 | * Used JWT Token for security and authentication of API. 150 | * MVC structure in which `Route`, `Service` and `Model` layer. 151 | * Used AJV as schema validator which validate request and response schema. 152 | * Used Connection Pooling which lead to reduce number of conncetion at any point of time and reduce stress in DB which leads to better availability and Performance of DB. 153 | * Used common error structure format for all type of error throwing in Application. 154 | * Includes `documents` folder which contain swagger representation both in JSON and HTML, which will help front-end developer for better understanding. 155 | * `Pm2` a process manager which help to watch, reload, restart and monitor with load balancer in each and every activity. 156 | * `nodemailer` is used to send mail over SMTP. as for i now used for sending mail if error comes. 157 | * `bcrypt` is used to encrypt your password through salt and hashing technique and which won't store password as plain text in database. 158 | * `artillery` is used to perform load testing which will check sustainibility of your API at `high traffic`. 159 | 160 | # Swagger Related task 161 | 162 | 1. How to Open Swagger - 163 | * [open](http://editor.swagger.io) 164 | 2. Go to `File` and `import file` option, import `JSON` file present in `document` folder. 165 | 3. To Download `HTML` file of particular `JSON` 166 | * Go to `Generate Client` option and `html2` option it will download html file. 167 | 4. Know more about Swagger [Check here](https://swagger.io/docs/) 168 | 169 | --- 170 | 171 | # Artillery Run 172 | 173 | 1. First go to `/loadtest` folder 174 | 2. you can use artillery in 2 way :- 175 | * by hardcoding data in yml file. 176 | * getting data by `.csv` file. 177 | 3. For option 1 run - `artillery run hello.yml` 178 | 4. For option 2 first get CSV file with data. 179 | 5. define path in yml file and run example as i Did :- `artillery run hellocsv.yml` 180 | 181 | 182 | 183 | 184 | 185 | -------------------------------------------------------------------------------- /app.js: -------------------------------------------------------------------------------- 1 | const apis = require("./config/api-config"); 2 | const PORT = 9890; 3 | 4 | apis.app.listen(process.env.PORT || PORT, function() { 5 | console.log("server connected to port " + PORT); 6 | }); 7 | -------------------------------------------------------------------------------- /app/models/authentic.model.js: -------------------------------------------------------------------------------- 1 | var db = require('../../config/database'); 2 | var dbFunc = require('../../config/db-function'); 3 | const bcrypt = require('bcrypt'); 4 | 5 | var authenticModel = { 6 | authentic: authentic, 7 | signup: signup 8 | } 9 | 10 | function authentic(authenticData) { 11 | return new Promise((resolve, reject) => { 12 | db.query(`SELECT * FROM user WHERE username ='${authenticData.username}'`, (error, rows, fields) => { 13 | if (error) { 14 | reject(error); 15 | } else { 16 | bcrypt.compare(authenticData.password, rows[0].password, function (err, isMatch) { 17 | if (err) { 18 | reject(error); 19 | } else if (isMatch) { 20 | resolve(rows); 21 | } 22 | else { 23 | reject({"success":false,"message":"password doesnot match"}); 24 | } 25 | }); 26 | 27 | } 28 | }); 29 | }); 30 | 31 | } 32 | 33 | 34 | function signup(user) { 35 | return new Promise((resolve, reject) => { 36 | bcrypt.genSalt(10, function (err, salt) { 37 | if (err) { 38 | return next(err); 39 | } 40 | bcrypt.hash(user.password, salt, function (err, hash) { 41 | if (err) { 42 | return next(err); 43 | } 44 | user.password = hash; 45 | db.query("SELECT * FROM user WHERE username='"+user.username+"'", (error, rows, fields) => { 46 | if (error) { 47 | dbFunc.connectionRelease; 48 | reject(error); 49 | } else if(rows.length>0) { 50 | dbFunc.connectionRelease; 51 | reject({"success":false,"message":"user already exist ! try with different user"}); 52 | } else { 53 | db.query("INSERT INTO user(username,password)VALUES('" + user.username + "','" + user.password + "')", (error, rows, fields) => { 54 | if (error) { 55 | dbFunc.connectionRelease; 56 | reject(error); 57 | } else { 58 | dbFunc.connectionRelease; 59 | resolve(rows); 60 | } 61 | }); 62 | } 63 | }); 64 | }) 65 | 66 | }); 67 | }); 68 | } 69 | 70 | module.exports = authenticModel; 71 | 72 | 73 | 74 | -------------------------------------------------------------------------------- /app/models/user-model.js: -------------------------------------------------------------------------------- 1 | var db = require('../../config/database'); 2 | var dbFunc = require('../../config/db-function'); 3 | 4 | var userModel = { 5 | getAllUser:getAllUser, 6 | addUser:addUser, 7 | updateUser:updateUser, 8 | deleteUser:deleteUser, 9 | getUserById:getUserById 10 | } 11 | 12 | function getAllUser() { 13 | return new Promise((resolve,reject) => { 14 | db.query(`CALL get_user()`,(error,rows,fields)=>{ 15 | if(!!error) { 16 | dbFunc.connectionRelease; 17 | reject(error); 18 | } else { 19 | dbFunc.connectionRelease; 20 | resolve(rows[0]); 21 | } 22 | }); 23 | }); 24 | } 25 | 26 | function getUserById(id) { 27 | return new Promise((resolve,reject) => { 28 | db.query("SELECT * FROM test WHERE id ="+id.id,(error,rows,fields)=>{ 29 | if(!!error) { 30 | dbFunc.connectionRelease; 31 | reject(error); 32 | } else { 33 | dbFunc.connectionRelease; 34 | resolve(rows); 35 | } 36 | }); 37 | }); 38 | } 39 | 40 | function addUser(user) { 41 | return new Promise((resolve,reject) => { 42 | db.query("INSERT INTO test(name,age,state,country)VALUES('"+user.name+"','"+user.age+"','"+user.state+"','"+user.country+"')",(error,rows,fields)=>{ 43 | if(error) { 44 | dbFunc.connectionRelease; 45 | reject(error); 46 | } else { 47 | dbFunc.connectionRelease; 48 | resolve(rows); 49 | } 50 | }); 51 | }); 52 | } 53 | 54 | 55 | function updateUser(id,user) { 56 | return new Promise((resolve,reject) => { 57 | db.query("UPDATE test set name='"+user.name+"',age='"+user.age+"',state='"+user.state+"',country='"+user.country+"' WHERE id='"+id+"'",(error,rows,fields)=>{ 58 | if(!!error) { 59 | dbFunc.connectionRelease; 60 | reject(error); 61 | } else { 62 | dbFunc.connectionRelease; 63 | resolve(rows); 64 | } 65 | }); 66 | }) 67 | } 68 | 69 | function deleteUser(id) { 70 | return new Promise((resolve,reject) => { 71 | db.query("DELETE FROM test WHERE id='"+id+"'",(error,rows,fields)=>{ 72 | if(!!error) { 73 | dbFunc.connectionRelease; 74 | reject(error); 75 | } else { 76 | dbFunc.connectionRelease; 77 | resolve(rows); 78 | } 79 | }); 80 | }); 81 | } 82 | 83 | 84 | module.exports = userModel; 85 | 86 | -------------------------------------------------------------------------------- /app/routes/authentic.route.js: -------------------------------------------------------------------------------- 1 | const authenticService = require('../services/authentic.service'); 2 | var schema = require('../schema/loginValidationSchema.json') 3 | var iValidator = require('../../common/iValidator'); 4 | var errorCode = require('../../common/error-code'); 5 | var errorMessage = require('../../common/error-methods'); 6 | var mail = require('./../../common/mailer.js'); 7 | 8 | 9 | const jwt = require('jsonwebtoken'); 10 | 11 | function init(router) { 12 | router.route('/login') 13 | .post(authentic); 14 | router.route('/signup') 15 | .post(signup); 16 | } 17 | 18 | function authentic(req,res) { 19 | var authenticData=req.body; 20 | 21 | //Validating the input entity 22 | var json_format = iValidator.json_schema(schema.postSchema, authenticData, "authentic"); 23 | if (json_format.valid == false) { 24 | return res.status(422).send(json_format.errorMessage); 25 | } 26 | 27 | authenticService.authentic(authenticData).then((data) => { 28 | if(data) { 29 | var username = data.username; 30 | const token = jwt.sign({username},'my_secret_key',{ expiresIn: 60*60*24 }); 31 | res.json({ 32 | "success":true, 33 | "data":data, 34 | "token":token 35 | }); 36 | } 37 | }).catch((err) => { 38 | mail.mail(err); 39 | res.json(err); 40 | }); 41 | 42 | } 43 | 44 | 45 | function signup(req,res) { 46 | var signUpData=req.body; 47 | 48 | //Validating the input entity 49 | var json_format = iValidator.json_schema(schema.postSchema, signUpData, "signUpData"); 50 | if (json_format.valid == false) { 51 | return res.status(422).send(json_format.errorMessage); 52 | } 53 | 54 | authenticService.signup(signUpData).then((data) => { 55 | if(data) { 56 | res.json({ 57 | "success":true, 58 | "data":data 59 | }); 60 | } 61 | }).catch((err) => { 62 | mail.mail(err); 63 | res.json(err); 64 | }); 65 | 66 | } 67 | 68 | 69 | 70 | module.exports.init = init; 71 | 72 | 73 | 74 | -------------------------------------------------------------------------------- /app/routes/user.route.js: -------------------------------------------------------------------------------- 1 | const userService = require('../services/user.service'); 2 | var schema = require('../schema/userValidationSchema.json') 3 | var iValidator = require('../../common/iValidator'); 4 | var errorCode = require('../../common/error-code'); 5 | var errorMessage = require('../../common/error-methods'); 6 | var mail = require('./../../common/mailer.js'); 7 | 8 | 9 | function init(router) { 10 | router.route('/user') 11 | .get(getAllUsers) 12 | .post(addUser); 13 | router.route('/user/:id') 14 | .get(getUserById) 15 | .delete(deleteUser) 16 | .put(updateUser); 17 | } 18 | 19 | function getAllUsers(req,res) { 20 | userService.getAllUser().then((data) => { 21 | res.send(data); 22 | }).catch((err) => { 23 | mail.mail(err); 24 | res.send(err); 25 | }); 26 | } 27 | 28 | function getUserById(req,res) { 29 | 30 | let userId = req.params; 31 | 32 | var json_format = iValidator.json_schema(schema.getSchema,userId,"user"); 33 | if (json_format.valid == false) { 34 | return res.status(422).send(json_format.errorMessage); 35 | } 36 | 37 | userService.getUserById(userId).then((data) => { 38 | res.send(data); 39 | }).catch((err) => { 40 | mail.mail(err); 41 | res.send(err); 42 | }); 43 | } 44 | 45 | function addUser(req,res) { 46 | var userData=req.body; 47 | 48 | //Validating the input entity 49 | var json_format = iValidator.json_schema(schema.postSchema, userData, "user"); 50 | if (json_format.valid == false) { 51 | return res.status(422).send(json_format.errorMessage); 52 | } 53 | 54 | userService.addUser(userData).then((data) => { 55 | res.json(data); 56 | }).catch((err) => { 57 | mail.mail(err); 58 | res.json(err); 59 | }); 60 | 61 | } 62 | 63 | 64 | function updateUser(req,res) { 65 | var userData=req.body; 66 | var id = req.params.id; 67 | userService.updateUser(id,userData).then((data)=>{ 68 | res.json(data); 69 | }).catch((err)=>{ 70 | mail.mail(err); 71 | res.json(err); 72 | }); 73 | } 74 | 75 | 76 | function deleteUser(req,res) { 77 | var delId = req.params.id; 78 | userService.deleteUser(delId).then((data)=>{ 79 | res.json(data); 80 | }).catch((err)=>{ 81 | mail.mail(err); 82 | res.json(err); 83 | }); 84 | } 85 | 86 | 87 | module.exports.init = init; 88 | 89 | 90 | 91 | -------------------------------------------------------------------------------- /app/schema/loginValidationSchema.json: -------------------------------------------------------------------------------- 1 | { 2 | "getSchema":{ 3 | "type": "object", 4 | "required": [ 5 | "id" 6 | ], 7 | "properties": { 8 | "id" : { 9 | "type": "string" 10 | } 11 | } 12 | }, 13 | "postSchema":{ 14 | "type": "object", 15 | "required": [ 16 | "username" 17 | ], 18 | "properties": { 19 | "username" : { 20 | "type": "string", 21 | "minLength": 1, 22 | "maxLength": 10 23 | }, 24 | "password" : { 25 | "type" : "string", 26 | "minLength": 1, 27 | "maxLength": 10 28 | } 29 | } 30 | } 31 | } -------------------------------------------------------------------------------- /app/schema/userValidationSchema.json: -------------------------------------------------------------------------------- 1 | { 2 | "getSchema":{ 3 | "type": "object", 4 | "required": [ 5 | "id" 6 | ], 7 | "properties": { 8 | "id" : { 9 | "type": "string" 10 | } 11 | } 12 | }, 13 | "postSchema":{ 14 | "type": "object", 15 | "required": [ 16 | "name" 17 | ], 18 | "properties": { 19 | "name" : { 20 | "type": "string", 21 | "minLength": 1, 22 | "maxLength": 10 23 | }, 24 | "age" : { 25 | "type" : "integer", 26 | "minimum": 1, 27 | "maximum": 150 28 | }, 29 | "state":{ 30 | "type": "string", 31 | "minLength": 1, 32 | "maxLength": 10 33 | }, 34 | "country": { 35 | "type": "string", 36 | "minLength": 1, 37 | "maxLength": 10 38 | } 39 | } 40 | } 41 | } -------------------------------------------------------------------------------- /app/services/authentic.service.js: -------------------------------------------------------------------------------- 1 | var authenticModel = require("../models/authentic.model"); 2 | 3 | 4 | var authenticService = { 5 | authentic: authentic, 6 | signup:signup 7 | } 8 | 9 | function authentic(authenticData) { 10 | return new Promise((resolve,reject) => { 11 | authenticModel.authentic(authenticData).then((data)=>{ 12 | resolve(data); 13 | }).catch((err) => { 14 | reject(err); 15 | }) 16 | }) 17 | 18 | } 19 | 20 | function signup(signUpData) { 21 | 22 | return new Promise((resolve,reject) => { 23 | authenticModel.signup(signUpData).then((data)=>{ 24 | resolve(data); 25 | }).catch((err) => { 26 | reject(err); 27 | }) 28 | }) 29 | 30 | } 31 | 32 | 33 | 34 | module.exports = authenticService; 35 | 36 | -------------------------------------------------------------------------------- /app/services/user.service.js: -------------------------------------------------------------------------------- 1 | var userModel = require("../models/user-model.js"); 2 | 3 | 4 | var userService = { 5 | getAllUser: getAllUser, 6 | getUserById:getUserById, 7 | addUser: addUser, 8 | updateUser:updateUser, 9 | deleteUser:deleteUser 10 | } 11 | 12 | function addUser(userData) { 13 | return new Promise((resolve,reject) => { 14 | userModel.addUser(userData).then((data)=>{ 15 | resolve(data); 16 | }).catch((err) => { 17 | reject(err); 18 | }) 19 | }) 20 | 21 | } 22 | 23 | 24 | function updateUser(id,userData,callback) { 25 | return new Promise((resolve,reject) => { 26 | userModel.updateUser(id,userData).then((data)=>{ 27 | resolve(data); 28 | }).catch((err) => { 29 | reject(err); 30 | }) 31 | }) 32 | 33 | } 34 | 35 | function deleteUser(id) { 36 | return new Promise((resolve,reject) => { 37 | userModel.deleteUser(id).then((data)=>{ 38 | resolve(data); 39 | }).catch((err) => { 40 | reject(err); 41 | }) 42 | }) 43 | } 44 | 45 | function getAllUser() { 46 | return new Promise((resolve,reject) => { 47 | userModel.getAllUser().then((data)=>{ 48 | resolve(data); 49 | }).catch((err) => { 50 | reject(err); 51 | }) 52 | }); 53 | } 54 | 55 | function getUserById(id) { 56 | return new Promise((resolve,reject) => { 57 | userModel.getUserById(id).then((data)=>{ 58 | resolve(data); 59 | }).catch((err) => { 60 | reject(err); 61 | }) 62 | }); 63 | } 64 | 65 | 66 | module.exports = userService; 67 | 68 | -------------------------------------------------------------------------------- /common/error-code.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | SUCCESS: {code:"SUCCESS",message:"Success"}, 3 | LOGIN_FAILED: {code:"LOGIN_FAILED",message:"Login Failed"}, 4 | INVALID_ENVIRONMENT_USER: {code:"INVALID_ENVIRONMENT_USER",message:"Invalid Environment User"}, 5 | EXCEED_EMAIL_LIMIT: {code: "EXCEED_EMAIL_LIMIT", message: "Maximum number of registration with same email address"}, 6 | INVALID_MEDIA_TYPE: {code: "INVALID_MEDIA_TYPE", message: "Invalid Media Type"}, 7 | INVALID_CONDITION: {code: "INVALID_CONDITION", message: "Invalid Condition"}, 8 | USERNAME_EMAIL_REQUIRED: {code: "USERNAME_EMAIL_REQUIRED", message: "Username Email Required"}, 9 | INVALID_MEDIA: {code: "INVALID_MEDIA", message: "Invalid Media"}, 10 | INVALID_DATA: {code: "INVALID_DATA", message: "Invalid data"}, 11 | NOT_FOUND: {code: "NOT_FOUND", message: "Resource not found"}, 12 | INVALID_FILE: {code: "INVALID_FILE", message: "Invalid File"}, 13 | LIMIT_REACHED : {code: "LIMIT_REACHED", message: "Order limit reached"}, 14 | ERROR_EMAIL : {code: "ERROR_EMAIL", message: "Email sending failed"}, 15 | VALIDATION_FAILED: {code: "VALIDATION_FAILED", message: "Validation rule failed"}, 16 | INVALID_TOKEN: {code: "INVALID_TOKEN", message: "Access Token is invalid"} 17 | } 18 | -------------------------------------------------------------------------------- /common/error-methods.js: -------------------------------------------------------------------------------- 1 | var errorCode = require('./error-code'); 2 | module.exports = { 3 | get: function (statusCode, error) { 4 | var name; 5 | if (error.code == "LOGIN_FAILED") { 6 | name = "Error" 7 | } else { 8 | name = "ValidationError" 9 | } 10 | return ({ 11 | error: { 12 | statusCode: statusCode, 13 | name: name, 14 | message: error.message, 15 | code: error.code 16 | } 17 | }) 18 | }, 19 | 20 | validationError: function (statusCode, errors, model) { 21 | console.log(errors); 22 | var codes = [], 23 | messages = [], 24 | errorCode; 25 | errors.map((error, i) => { 26 | var errorConcat = ""; 27 | error.dataPath = error.dataPath.slice(1); 28 | console.log("error.dataPath initial",error.dataPath); 29 | if (!error.dataPath) { 30 | error.dataPath = error.params.missingProperty; 31 | } 32 | 33 | // codes - array of codes 34 | 35 | var errorKeyword = error.dataPath.split("."); 36 | errorKeyword.map((values) => { 37 | errorConcat += values + "_" 38 | }); 39 | 40 | switch (error.keyword) { 41 | case "required": 42 | errorCode = (errorConcat + error.keyword).toUpperCase(); 43 | break; 44 | case "format": 45 | errorCode = errorConcat.toUpperCase() + "INVALID_FORMAT"; 46 | break; 47 | case "type": 48 | errorCode = errorConcat.toUpperCase() + "INVALID_TYPE"; 49 | break; 50 | case "minLength": 51 | case "maxLength": 52 | case "maximum": 53 | case "minimum": 54 | errorCode = errorConcat.toUpperCase() + "INVALID_LENGTH"; 55 | break; 56 | default: 57 | errorCode = error.keyword.toUpperCase(); 58 | } 59 | codes.push(errorCode); 60 | let message = {}; 61 | message[errorCode] = error.message 62 | messages.push(message); 63 | }) 64 | 65 | return ({ 66 | error: { 67 | statusCode: statusCode, 68 | name: "ValidationError", 69 | message: 'Unprocessable Entity', 70 | details: { 71 | context: model, 72 | codes: codes, 73 | messages: messages 74 | } 75 | } 76 | }) 77 | }, 78 | 79 | getErrorCode: function (statusCodeValue) { 80 | if (errorCode[statusCodeValue]) 81 | return errorCode[statusCodeValue]; 82 | else 83 | return errorCode.INVALID_DATA 84 | } 85 | } 86 | -------------------------------------------------------------------------------- /common/iValidator.js: -------------------------------------------------------------------------------- 1 | 2 | var errorCode = require('./error-code') 3 | var errorMessage = require('./error-methods') 4 | var Ajv = require('ajv'); 5 | var schemaValidator = Ajv({ 6 | allErrors: true 7 | }); 8 | 9 | module.exports = { 10 | json_schema: function (schema, data, model) { 11 | 12 | var testSchemaValidator = schemaValidator.compile(schema); 13 | var valid = testSchemaValidator(data); 14 | if (valid) 15 | return ({ 16 | valid: true 17 | }); 18 | else { 19 | return ({ 20 | valid: false, 21 | errorMessage: errorMessage.validationError(422, testSchemaValidator.errors, model) 22 | }) 23 | } 24 | 25 | } 26 | } -------------------------------------------------------------------------------- /common/mailer.js: -------------------------------------------------------------------------------- 1 | var nodemailer = require("nodemailer"); 2 | 3 | var smtpTransport = nodemailer.createTransport({ 4 | service: "Yahoo", // sets automatically host, port and connection security settings 5 | auth: { 6 | user: "xxxxxxxxxx95@yahoo.com", 7 | pass: "xxxxxxxxxxxx" 8 | } 9 | }); 10 | 11 | function mail(messageBody) { 12 | let messageBodyJson = JSON.stringify(messageBody) 13 | smtpTransport.sendMail({ //email options 14 | from: "xxxxxxxxxx95@yahoo.com", // sender address. Must be the same as authenticated user if using Gmail. 15 | to: "xxxxxxxxxx95@gmail.com", // receiver 16 | subject: "Emailing with nodemailer", // subject 17 | text: messageBodyJson // body 18 | }, function(error, response){ //callback 19 | if(error){ 20 | console.log("error",error); 21 | }else{ 22 | console.log(response); 23 | } 24 | 25 | // smtpTransport.close(); // shut down the connection pool, no more messages. Comment this line out to continue sending emails. 26 | }); 27 | } 28 | 29 | module.exports = { 30 | mail:mail 31 | } 32 | -------------------------------------------------------------------------------- /config/api-config.js: -------------------------------------------------------------------------------- 1 | var express = require("express"); 2 | var app = express(); 3 | var path = require('path'); 4 | const mysql = require('mysql'); 5 | const jwt = require('jsonwebtoken'); 6 | var db = require('./database'); 7 | var dbfunc = require('./db-function'); 8 | var http = require('http') 9 | var bodyParser = require('body-parser'); 10 | var UserRoute = require('../app/routes/user.route'); 11 | var AuthenticRoute = require('../app/routes/authentic.route'); 12 | var errorCode = require('../common/error-code') 13 | var errorMessage = require('../common/error-methods') 14 | var checkToken = require('./secureRoute'); 15 | 16 | // var schedule = require('node-schedule'); 17 | 18 | // var j = schedule.scheduleJob('*/1 * * * *', function(){ 19 | // console.log('The answer to life, the universe, and everything!'); 20 | // }); 21 | 22 | dbfunc.connectionCheck.then((data) =>{ 23 | //console.log(data); 24 | }).catch((err) => { 25 | console.log(err); 26 | }); 27 | 28 | app.use(function(req, res, next) { 29 | res.header('Access-Control-Allow-Origin', '*'); 30 | res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS'); 31 | res.header('Access-Control-Allow-Headers', 'Content-Type'); 32 | next(); 33 | }); 34 | 35 | app.use(bodyParser.json()); 36 | 37 | var router = express.Router(); 38 | app.use('/api',router); 39 | AuthenticRoute.init(router); 40 | 41 | var secureApi = express.Router(); 42 | 43 | //set static folder 44 | app.use(express.static(path.join(__dirname, 'public'))); 45 | 46 | //body parser middleware 47 | 48 | app.use('/secureApi',secureApi); 49 | secureApi.use(checkToken); 50 | 51 | 52 | app.use(function (err, req, res, next) { 53 | console.error(err.stack); 54 | res.status(500).send('Something broke!'); 55 | }); 56 | 57 | 58 | // index route 59 | app.get('/', (req,res) => { 60 | res.send('hello world'); 61 | }); 62 | 63 | var ApiConfig = { 64 | app: app 65 | } 66 | 67 | UserRoute.init(secureApi); 68 | 69 | module.exports = ApiConfig; 70 | -------------------------------------------------------------------------------- /config/database.js: -------------------------------------------------------------------------------- 1 | const mysql = require('mysql'); 2 | 3 | module.exports = mysql.createPool({ 4 | connectionLimit : 100, 5 | host : 'localhost', 6 | user : 'root', 7 | password: '', 8 | database: 'sampleDB' 9 | }) 10 | 11 | 12 | 13 | 14 | 15 | -------------------------------------------------------------------------------- /config/db-function.js: -------------------------------------------------------------------------------- 1 | const db = require('./database'); 2 | //console.log("db",db); 3 | 4 | function connectionCheck() { 5 | return new Promise((resolve,reject) => { 6 | db.getConnection(function(err, connection) { 7 | if(err) { 8 | if(connection) connection.release(); 9 | reject(err) 10 | } else { 11 | resolve('success') 12 | } 13 | }) 14 | }) 15 | } 16 | 17 | function connectionRelease() { 18 | db.on('release', function (connection) { 19 | console.log('Connection %d released', connection.threadId); 20 | }); 21 | } 22 | 23 | module.exports = { 24 | connectionCheck:connectionCheck(), 25 | connectionRelease:connectionRelease() 26 | } 27 | -------------------------------------------------------------------------------- /config/secureRoute.js: -------------------------------------------------------------------------------- 1 | const jwt = require('jsonwebtoken'); 2 | 3 | module.exports = function checkToken(req, res, next) { 4 | var token = req.headers['token']; 5 | if(token) { 6 | jwt.verify(token, 'my_secret_key',(err,decode)=>{ 7 | if(err) { 8 | res.json({"status":500, 9 | "message":"INVALID TOKEN", 10 | "error":err.message 11 | }); 12 | } else { 13 | next(); 14 | } 15 | }) 16 | } else { 17 | res.json({"status":500, 18 | "message":"NO TOKEN PROVIDE", 19 | "error":"token must be provide in header for endpoint access" 20 | }); 21 | } 22 | } 23 | 24 | 25 | -------------------------------------------------------------------------------- /documents/sql-script/script_v1.sql: -------------------------------------------------------------------------------- 1 | 2 | CREATE TABLE [dbo].[User]( 3 | [id] [int] IDENTITY(1,1) NOT NULL, 4 | [username] [bit] NULL, 5 | [password] [int] NULL, 6 | [CreatedDate] [datetime] NULL, 7 | [UpdatedDate] [datetime] NULL, 8 | [UpdatedBy] [int] NULL, 9 | [IsEnabled] [bit] NULL, 10 | ) 11 | GO 12 | 13 | SELECT * FROM User; -------------------------------------------------------------------------------- /documents/swagger/swagger_v1.json: -------------------------------------------------------------------------------- 1 | { 2 | "swagger": "2.0", 3 | "info": { 4 | "version": "1.0.0", 5 | "title": "Node and Mysql swagger documentation", 6 | "description": "This is aimed to maintain sampling related transactions like user and other etc. ", 7 | "termsOfService": "http://www.itjunkies.in", 8 | "contact": { 9 | "name": "yugagrawal95@gmail.com" 10 | } 11 | }, 12 | "host": "dev.itjunkies.in", 13 | "basePath": "/", 14 | "schemes": [ 15 | "http", 16 | "https" 17 | ], 18 | "consumes": [ 19 | "application/x-www-form-urlencoded" 20 | ], 21 | "produces": [ 22 | "application/json" 23 | ], 24 | "paths": { 25 | "/api/login": { 26 | "post": { 27 | "tags": [ 28 | "Login" 29 | ], 30 | "description": "Returns access token", 31 | "operationId": "Login", 32 | "consumes": [ 33 | "application/x-www-form-urlencoded" 34 | ], 35 | "produces": [ 36 | "application/json" 37 | ], 38 | "parameters": [ 39 | { 40 | "name": "Content-Type", 41 | "in": "header", 42 | "required": true, 43 | "type": "string", 44 | "description": "Content-Type entity header is used to indicate the media type of the resource. Accepted value 'application/x-www-form-urlencoded'" 45 | }, 46 | { 47 | "name": "request", 48 | "in": "body", 49 | "required": true, 50 | "schema": { 51 | "$ref": "#/definitions/auth" 52 | } 53 | } 54 | ], 55 | "responses": { 56 | "201": { 57 | "description": "Login Response", 58 | "schema": { 59 | "$ref": "#/definitions/authTokenResponse" 60 | } 61 | }, 62 | "401": { 63 | "description": "Bad Request", 64 | "schema": { 65 | "$ref": "#/definitions/errorModel401Auth" 66 | } 67 | }, 68 | "404": { 69 | "description": "Not Found", 70 | "schema": { 71 | "$ref": "#/definitions/errorModel404" 72 | } 73 | }, 74 | "500": { 75 | "description": "Internal Server Error", 76 | "schema": { 77 | "$ref": "#/definitions/errorModel500" 78 | } 79 | } 80 | } 81 | } 82 | }, 83 | "/secureApi/user": { 84 | "post": { 85 | "tags": [ 86 | "User model" 87 | ], 88 | "description": "Add a new user", 89 | "operationId": "User", 90 | "consumes": [ 91 | "application/x-www-form-urlencoded" 92 | ], 93 | "produces": [ 94 | "application/json" 95 | ], 96 | "parameters": [ 97 | { 98 | "name": "Content-Type", 99 | "in": "header", 100 | "required": true, 101 | "type": "string", 102 | "description": "Content-Type entity header is used to indicate the media type of the resource. Accepted value 'application/x-www-form-urlencoded'" 103 | }, 104 | { 105 | "name": "access_token", 106 | "in": "header", 107 | "required": true, 108 | "description": "access token can be generated using auth/login end point.
ex: access_token = kQ60GIXXXXoG8x8", 109 | "type": "string" 110 | }, 111 | { 112 | "name": "request", 113 | "in": "body", 114 | "description": "Feedback object needs to be saved", 115 | "required": true, 116 | "schema": { 117 | "$ref": "#/definitions/userRequest" 118 | } 119 | } 120 | ], 121 | "responses": { 122 | "201": { 123 | "description": "Successful operation", 124 | "schema": { 125 | "$ref": "#/definitions/userResponse" 126 | } 127 | }, 128 | "400": { 129 | "description": "Bad Request", 130 | "schema": { 131 | "$ref": "#/definitions/errorModel400Feedback" 132 | } 133 | }, 134 | "401": { 135 | "description": "Unauthorized", 136 | "schema": { 137 | "$ref": "#/definitions/errorModel401" 138 | } 139 | }, 140 | "404": { 141 | "description": "Not Found", 142 | "schema": { 143 | "$ref": "#/definitions/errorModel404" 144 | } 145 | }, 146 | "422": { 147 | "description": "Validation Error", 148 | "schema": { 149 | "$ref": "#/definitions/errorModelValidationFeedback" 150 | } 151 | }, 152 | "500": { 153 | "description": "Internal Server Error", 154 | "schema": { 155 | "$ref": "#/definitions/errorModel500" 156 | } 157 | } 158 | } 159 | }, 160 | "get": { 161 | "tags": [ 162 | "User model" 163 | ], 164 | "description": "get all user", 165 | "operationId": "get User", 166 | "consumes": [ 167 | "application/x-www-form-urlencoded" 168 | ], 169 | "produces": [ 170 | "application/json" 171 | ], 172 | "parameters": [ 173 | { 174 | "name": "Content-Type", 175 | "in": "header", 176 | "required": true, 177 | "type": "string", 178 | "description": "Content-Type entity header is used to indicate the media type of the resource. Accepted value 'application/x-www-form-urlencoded'" 179 | }, 180 | { 181 | "name": "token", 182 | "in": "header", 183 | "required": true, 184 | "description": "access token can be generated using auth/login end point.
ex: access_token = kQ60GIXXXXoG8x8", 185 | "type": "string" 186 | } 187 | ], 188 | "responses": { 189 | "201": { 190 | "description": "Successful operation", 191 | "schema": { 192 | "$ref": "#/definitions/userResponse" 193 | } 194 | }, 195 | "400": { 196 | "description": "Bad Request", 197 | "schema": { 198 | "$ref": "#/definitions/errorModel400Feedback" 199 | } 200 | }, 201 | "401": { 202 | "description": "Unauthorized", 203 | "schema": { 204 | "$ref": "#/definitions/errorModel401" 205 | } 206 | }, 207 | "404": { 208 | "description": "Not Found", 209 | "schema": { 210 | "$ref": "#/definitions/errorModel404" 211 | } 212 | }, 213 | "422": { 214 | "description": "Validation Error", 215 | "schema": { 216 | "$ref": "#/definitions/errorModelValidationFeedback" 217 | } 218 | }, 219 | "500": { 220 | "description": "Internal Server Error", 221 | "schema": { 222 | "$ref": "#/definitions/errorModel500" 223 | } 224 | } 225 | } 226 | } 227 | }, 228 | "/secureApi/user/{userId}": { 229 | "delete": { 230 | "tags": [ 231 | "User model" 232 | ], 233 | "description": "Add a new user", 234 | "operationId": "delete User", 235 | "consumes": [ 236 | "application/x-www-form-urlencoded" 237 | ], 238 | "produces": [ 239 | "application/json" 240 | ], 241 | "parameters": [ 242 | { 243 | "name": "Content-Type", 244 | "in": "header", 245 | "required": true, 246 | "type": "string", 247 | "description": "Content-Type entity header is used to indicate the media type of the resource. Accepted value 'application/x-www-form-urlencoded'" 248 | }, 249 | { 250 | "name": "access_token", 251 | "in": "header", 252 | "required": true, 253 | "description": "access token can be generated using auth/login end point.
ex: access_token = kQ60GIXXXXoG8x8", 254 | "type": "string" 255 | }, 256 | { 257 | "name": "userId", 258 | "in": "path", 259 | "required": true, 260 | "description": "userId", 261 | "type": "string" 262 | }, 263 | { 264 | "name": "request", 265 | "in": "body", 266 | "description": "Feedback object needs to be saved", 267 | "required": true, 268 | "schema": { 269 | "$ref": "#/definitions/userRequest" 270 | } 271 | } 272 | ], 273 | "responses": { 274 | "201": { 275 | "description": "Successful operation", 276 | "schema": { 277 | "$ref": "#/definitions/userResponse" 278 | } 279 | }, 280 | "400": { 281 | "description": "Bad Request", 282 | "schema": { 283 | "$ref": "#/definitions/errorModel400Feedback" 284 | } 285 | }, 286 | "401": { 287 | "description": "Unauthorized", 288 | "schema": { 289 | "$ref": "#/definitions/errorModel401" 290 | } 291 | }, 292 | "404": { 293 | "description": "Not Found", 294 | "schema": { 295 | "$ref": "#/definitions/errorModel404" 296 | } 297 | }, 298 | "422": { 299 | "description": "Validation Error", 300 | "schema": { 301 | "$ref": "#/definitions/errorModelValidationFeedback" 302 | } 303 | }, 304 | "500": { 305 | "description": "Internal Server Error", 306 | "schema": { 307 | "$ref": "#/definitions/errorModel500" 308 | } 309 | } 310 | } 311 | }, 312 | "put": { 313 | "tags": [ 314 | "User model" 315 | ], 316 | "description": "get all user", 317 | "operationId": "update User", 318 | "consumes": [ 319 | "application/x-www-form-urlencoded" 320 | ], 321 | "produces": [ 322 | "application/json" 323 | ], 324 | "parameters": [ 325 | { 326 | "name": "Content-Type", 327 | "in": "header", 328 | "required": true, 329 | "type": "string", 330 | "description": "Content-Type entity header is used to indicate the media type of the resource. Accepted value 'application/x-www-form-urlencoded'" 331 | }, 332 | { 333 | "name": "token", 334 | "in": "header", 335 | "required": true, 336 | "description": "access token can be generated using auth/login end point.
ex: access_token = kQ60GIXXXXoG8x8", 337 | "type": "string" 338 | }, 339 | { 340 | "name": "userId", 341 | "in": "path", 342 | "required": true, 343 | "description": "userId", 344 | "type": "string" 345 | } 346 | ], 347 | "responses": { 348 | "201": { 349 | "description": "Successful operation", 350 | "schema": { 351 | "$ref": "#/definitions/userResponse" 352 | } 353 | }, 354 | "400": { 355 | "description": "Bad Request", 356 | "schema": { 357 | "$ref": "#/definitions/errorModel400Feedback" 358 | } 359 | }, 360 | "401": { 361 | "description": "Unauthorized", 362 | "schema": { 363 | "$ref": "#/definitions/errorModel401" 364 | } 365 | }, 366 | "404": { 367 | "description": "Not Found", 368 | "schema": { 369 | "$ref": "#/definitions/errorModel404" 370 | } 371 | }, 372 | "422": { 373 | "description": "Validation Error", 374 | "schema": { 375 | "$ref": "#/definitions/errorModelValidationFeedback" 376 | } 377 | }, 378 | "500": { 379 | "description": "Internal Server Error", 380 | "schema": { 381 | "$ref": "#/definitions/errorModel500" 382 | } 383 | } 384 | } 385 | } 386 | } 387 | }, 388 | "definitions": { 389 | "userRequest": { 390 | "type": "object", 391 | "required": [ 392 | "username", 393 | "password" 394 | ], 395 | "properties": { 396 | "username": { 397 | "type": "string", 398 | "maxLength": 10, 399 | "description": "name of user.", 400 | "example": 1 401 | }, 402 | "password":{ 403 | "type": "string", 404 | "maxLength": 10, 405 | "description": "password of user.", 406 | "example": 1 407 | } 408 | } 409 | }, 410 | "userResponse": { 411 | "type": "array", 412 | "items":{ 413 | "properties": { 414 | "id":{ 415 | "type": "integer", 416 | "description": "id of username" 417 | }, 418 | "username": { 419 | "type": "string", 420 | "description": "All username" 421 | }, 422 | "password": { 423 | "type": "string", 424 | "description": "related username password" 425 | } 426 | } 427 | } 428 | }, 429 | "auth": { 430 | "type": "object", 431 | "required": [ 432 | "username", 433 | "password" 434 | ], 435 | "properties": { 436 | "username": { 437 | "type": "string", 438 | "maxLength": 100, 439 | "description": "username" 440 | }, 441 | "password": { 442 | "type": "string", 443 | "maxLength": 100, 444 | "description": "Password matching the username." 445 | } 446 | } 447 | }, 448 | "authTokenResponse": { 449 | "type": "object", 450 | "required": [ 451 | "access_token", 452 | "ttl", 453 | "created", 454 | "userId" 455 | ], 456 | "properties": { 457 | "access_token": { 458 | "type": "string", 459 | "maxLength": 360, 460 | "description": "Access token of loggged in user. The token offers access to a specific resource for a time period.", 461 | "example": "kQ60GITBqiwNH6eS3SrRpJ30fafbGxcnGnaJWUdmNFSV0eniGa3NZHG2uRRoG8x8" 462 | }, 463 | "ttl": { 464 | "type": "integer", 465 | "format": "int32", 466 | "description": "A ttl (time to live) property with a value in seconds describes how long the access token is valid." 467 | }, 468 | "created": { 469 | "type": "string", 470 | "description": "TimeStamp when access token (id) is created." 471 | }, 472 | "userId": { 473 | "type": "integer", 474 | "format": "int32", 475 | "description": "Unique id of logged in user" 476 | }, 477 | "expireBy": { 478 | "type": "string", 479 | "description": "TimeStamp when access token (id) gets expired." 480 | } 481 | } 482 | }, 483 | "errorModel401Auth": { 484 | "type": "object", 485 | "properties": { 486 | "error": { 487 | "type": "object", 488 | "required": [ 489 | "statusCode", 490 | "name", 491 | "message", 492 | "code" 493 | ], 494 | "properties": { 495 | "statusCode": { 496 | "type": "integer", 497 | "format": "int32", 498 | "description": "A number to identify specific problems encountered during the API invocation.", 499 | "example": 400 500 | }, 501 | "name": { 502 | "type": "string", 503 | "description": "Name of the error.", 504 | "maxLength": 1000 505 | }, 506 | "message": { 507 | "type": "string", 508 | "description": "The error message.", 509 | "maxLength": 1000 510 | }, 511 | "code": { 512 | "type": "string", 513 | "description": "Short Description of error.
example:LOGIN_FAILED, INVALID_TOKEN", 514 | "example": "LOGIN_FAILED" 515 | } 516 | } 517 | } 518 | } 519 | }, 520 | "errorModel400Feedback": { 521 | "type": "object", 522 | "properties": { 523 | "error": { 524 | "type": "object", 525 | "required": [ 526 | "statusCode", 527 | "name", 528 | "message", 529 | "code" 530 | ], 531 | "properties": { 532 | "statusCode": { 533 | "type": "integer", 534 | "format": "int32", 535 | "description": "A number to identify specific problems encountered during the API invocation.", 536 | "example": 400 537 | }, 538 | "name": { 539 | "type": "string", 540 | "description": "Name of the error.", 541 | "maxLength": 1000 542 | }, 543 | "message": { 544 | "type": "string", 545 | "description": "The error message.", 546 | "maxLength": 1000 547 | }, 548 | "code": { 549 | "type": "string", 550 | "description": "Short Description of error.
example:INVALID_USER", 551 | "example": "INVALID_USER" 552 | } 553 | } 554 | } 555 | } 556 | }, 557 | "errorModel400MediaType": { 558 | "type": "object", 559 | "properties": { 560 | "error": { 561 | "type": "object", 562 | "required": [ 563 | "statusCode", 564 | "name", 565 | "message", 566 | "code" 567 | ], 568 | "properties": { 569 | "statusCode": { 570 | "type": "integer", 571 | "format": "int32", 572 | "description": "A number to identify specific problems encountered during the API invocation.", 573 | "example": 400 574 | }, 575 | "name": { 576 | "type": "string", 577 | "description": "Name of the error.", 578 | "maxLength": 1000 579 | }, 580 | "message": { 581 | "type": "string", 582 | "description": "The error message.", 583 | "maxLength": 1000 584 | }, 585 | "code": { 586 | "type": "string", 587 | "description": "Short Description of error.
example:INVALID_FILE", 588 | "example": "INVALID_FILE" 589 | } 590 | } 591 | } 592 | } 593 | }, 594 | "errorModel401": { 595 | "type": "object", 596 | "properties": { 597 | "error": { 598 | "type": "object", 599 | "required": [ 600 | "statusCode", 601 | "name", 602 | "message", 603 | "code" 604 | ], 605 | "properties": { 606 | "statusCode": { 607 | "type": "integer", 608 | "format": "int32", 609 | "description": "A number to identify specific problems encountered during the API invocation.", 610 | "example": 401 611 | }, 612 | "name": { 613 | "type": "string", 614 | "description": "Name of the error.", 615 | "maxLength": 1000 616 | }, 617 | "message": { 618 | "type": "string", 619 | "description": "The error message.", 620 | "maxLength": 1000 621 | }, 622 | "code": { 623 | "type": "string", 624 | "description": "Short Description of error.
example: AUTHORIZATION_REQUIRED, INVALID_TOKEN", 625 | "example": "AUTHORIZATION_REQUIRED" 626 | } 627 | } 628 | } 629 | } 630 | }, 631 | "errorModel500": { 632 | "type": "object", 633 | "properties": { 634 | "error": { 635 | "type": "object", 636 | "required": [ 637 | "statusCode", 638 | "name", 639 | "message", 640 | "code" 641 | ], 642 | "properties": { 643 | "statusCode": { 644 | "type": "integer", 645 | "format": "int32", 646 | "description": "A number to identify specific problems encountered during the API invocation.", 647 | "example": 500 648 | }, 649 | "name": { 650 | "type": "string", 651 | "description": "Name of the error.", 652 | "maxLength": 1000 653 | }, 654 | "message": { 655 | "type": "string", 656 | "description": "The error message.", 657 | "maxLength": 1000, 658 | "example": "Internal Server Error" 659 | }, 660 | "code": { 661 | "type": "string", 662 | "description": "Code of the error. Example: EREQUEST, EPARAM", 663 | "example": "EREQUEST" 664 | } 665 | } 666 | } 667 | } 668 | }, 669 | "errorModel404": { 670 | "type": "object", 671 | "properties": { 672 | "error": { 673 | "type": "object", 674 | "required": [ 675 | "statusCode", 676 | "name", 677 | "message" 678 | ], 679 | "properties": { 680 | "statusCode": { 681 | "type": "integer", 682 | "format": "int32", 683 | "description": "A number to identify specific problems encountered during the API invocation.", 684 | "example": 404 685 | }, 686 | "name": { 687 | "type": "string", 688 | "description": "Name of the error.", 689 | "maxLength": 1000 690 | }, 691 | "message": { 692 | "type": "string", 693 | "description": "The error message.", 694 | "maxLength": 1000 695 | }, 696 | "code": { 697 | "type": "string", 698 | "description": "Code of the error. Example: NOT_FOUND", 699 | "example": "NOT_FOUND" 700 | } 701 | } 702 | } 703 | } 704 | }, 705 | "errorModelValidationFeedback": { 706 | "type": "object", 707 | "properties": { 708 | "error": { 709 | "type": "object", 710 | "required": [ 711 | "statusCode", 712 | "name", 713 | "message" 714 | ], 715 | "properties": { 716 | "statusCode": { 717 | "type": "integer", 718 | "format": "int32", 719 | "description": "A number to identify specific problems encountered during the API invocation.", 720 | "example": 422 721 | }, 722 | "name": { 723 | "type": "string", 724 | "description": "Name of the error.", 725 | "maxLength": 1000 726 | }, 727 | "message": { 728 | "type": "string", 729 | "description": "The error message.", 730 | "maxLength": 1000 731 | }, 732 | "details": { 733 | "type": "object", 734 | "description": "Details of the error.", 735 | "properties": { 736 | "context": { 737 | "type": "object", 738 | "description": "Object containing context details." 739 | }, 740 | "codes": { 741 | "type": "array", 742 | "items": {}, 743 | "description": "An array containing error codes of the entity passed in body/query string.

Format of the error code is as below
{property of object}_REQUIRED : Property is mandatory in the entity.
{property of object}_INVALID_TYPE: Property type is not matching. Ex: Integer, String etc.
{property of object}_INVALID_FORMAT: Property format is not as expected. Ex: Date format.
{property of object}_INVALID_LENGTH: Property length is not matching.

Example: CAMPAIGN_REQUIRED, CONSUMER_NAME_INVALID_TYPE, MEDIA[0]_INVALID_TYPE" 744 | }, 745 | "messages": { 746 | "type": "array", 747 | "items": {}, 748 | "description": "An array containing detail error message.

Example:
[ {'CAMPAIGN_REQUIRED':'should have required property campaign'}, {'CONSUMER_NAME_INVALID_TYPE':'should be string'}, {'MEDIA[0]_INVALID_TYPE': 'should be integer'}]" 749 | } 750 | } 751 | } 752 | } 753 | } 754 | } 755 | } 756 | } 757 | } -------------------------------------------------------------------------------- /loadtest/hello.csv: -------------------------------------------------------------------------------- 1 | name,age,state,country 2 | Emmy,11,Goa,india -------------------------------------------------------------------------------- /loadtest/hello.yml: -------------------------------------------------------------------------------- 1 | config: 2 | target: 'http://localhost:9890' 3 | phases: 4 | - duration: 60 5 | arrivalRate: 200 6 | defaults: 7 | headers: 8 | token: 'token' 9 | scenarios: 10 | - flow: 11 | - post: 12 | url: "/secureApi/user" 13 | json: 14 | name: "lokesh" 15 | age: 22 16 | state: "karna" 17 | country: "india" 18 | 19 | -------------------------------------------------------------------------------- /loadtest/hellocsv.yml: -------------------------------------------------------------------------------- 1 | config: 2 | target: 'http://localhost:9890' 3 | phases: 4 | - duration: 60 5 | arrivalRate: 10 6 | defaults: 7 | headers: 8 | token: 'token' 9 | payload: 10 | path: "./hello.csv" 11 | fields: 12 | - "name" 13 | - "age" 14 | - "state" 15 | - "country" 16 | scenarios: 17 | - flow: 18 | - post: 19 | url: "/secureApi/user" 20 | json: 21 | name: "{{name}}" 22 | age: !! "{{age}}" 23 | state: "{{state}}" 24 | country: "{{country}}" 25 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "node-mysql-boilerplate", 3 | "version": "1.0.7", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@remy/pstree": { 8 | "version": "1.1.0", 9 | "resolved": "https://registry.npmjs.org/@remy/pstree/-/pstree-1.1.0.tgz", 10 | "integrity": "sha512-3rxECj41p0Qkdgoc50VnZpSDTXS+UZGRzTTO+qb3TiZDhuZMmf4z/wApcIeJ878okVq7D9phadgXQD9Kvbq3tQ==", 11 | "requires": { 12 | "ps-tree": "1.1.0" 13 | } 14 | }, 15 | "abbrev": { 16 | "version": "1.1.1", 17 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 18 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 19 | }, 20 | "accepts": { 21 | "version": "https://registry.npmjs.org/accepts/-/accepts-1.3.3.tgz", 22 | "integrity": "sha1-w8p0NJOGSMPg2cHjKN1otiLChMo=", 23 | "requires": { 24 | "mime-types": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.15.tgz", 25 | "negotiator": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz" 26 | } 27 | }, 28 | "ajv": { 29 | "version": "5.5.0", 30 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.0.tgz", 31 | "integrity": "sha1-6yhAdG6dxIvV4GOjbj/UAMXqtak=", 32 | "requires": { 33 | "co": "4.6.0", 34 | "fast-deep-equal": "1.0.0", 35 | "fast-json-stable-stringify": "2.0.0", 36 | "json-schema-traverse": "0.3.1" 37 | } 38 | }, 39 | "amp": { 40 | "version": "0.3.1", 41 | "resolved": "https://registry.npmjs.org/amp/-/amp-0.3.1.tgz", 42 | "integrity": "sha1-at+NWKdPNh6CwfqNOJwHnhOfxH0=" 43 | }, 44 | "amp-message": { 45 | "version": "0.1.2", 46 | "resolved": "https://registry.npmjs.org/amp-message/-/amp-message-0.1.2.tgz", 47 | "integrity": "sha1-p48cmJlQh602GSpBKY5NtJ49/EU=", 48 | "requires": { 49 | "amp": "0.3.1" 50 | } 51 | }, 52 | "ansi-align": { 53 | "version": "2.0.0", 54 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-2.0.0.tgz", 55 | "integrity": "sha1-w2rsy6VjuJzrVW82kPCx2eNUf38=", 56 | "requires": { 57 | "string-width": "2.1.1" 58 | } 59 | }, 60 | "ansi-regex": { 61 | "version": "3.0.0", 62 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 63 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 64 | }, 65 | "ansi-styles": { 66 | "version": "3.2.0", 67 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 68 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 69 | "requires": { 70 | "color-convert": "1.9.1" 71 | } 72 | }, 73 | "anymatch": { 74 | "version": "1.3.2", 75 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", 76 | "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", 77 | "requires": { 78 | "micromatch": "2.3.11", 79 | "normalize-path": "2.1.1" 80 | } 81 | }, 82 | "aproba": { 83 | "version": "1.2.0", 84 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 85 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 86 | }, 87 | "are-we-there-yet": { 88 | "version": "1.1.4", 89 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz", 90 | "integrity": "sha1-u13KOCu5TwXhUZQ3PRb9O6HKEQ0=", 91 | "requires": { 92 | "delegates": "1.0.0", 93 | "readable-stream": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz" 94 | } 95 | }, 96 | "argparse": { 97 | "version": "1.0.9", 98 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz", 99 | "integrity": "sha1-c9g7wmP4bpf4zE9rrhsOkKfSLIY=", 100 | "requires": { 101 | "sprintf-js": "1.0.3" 102 | }, 103 | "dependencies": { 104 | "sprintf-js": { 105 | "version": "1.0.3", 106 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 107 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 108 | } 109 | } 110 | }, 111 | "arr-diff": { 112 | "version": "2.0.0", 113 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 114 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 115 | "requires": { 116 | "arr-flatten": "1.1.0" 117 | } 118 | }, 119 | "arr-flatten": { 120 | "version": "1.1.0", 121 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 122 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" 123 | }, 124 | "array-flatten": { 125 | "version": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 126 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 127 | }, 128 | "array-unique": { 129 | "version": "0.2.1", 130 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 131 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=" 132 | }, 133 | "asn1": { 134 | "version": "0.2.3", 135 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", 136 | "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=" 137 | }, 138 | "assert-plus": { 139 | "version": "1.0.0", 140 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 141 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 142 | }, 143 | "async-each": { 144 | "version": "1.0.1", 145 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", 146 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=" 147 | }, 148 | "async-listener": { 149 | "version": "0.6.8", 150 | "resolved": "https://registry.npmjs.org/async-listener/-/async-listener-0.6.8.tgz", 151 | "integrity": "sha512-1Sy1jDhjlgxcSd9/ICHqiAHT8VSJ9R1lzEyWwP/4Hm9p8nVTNtU0SxG/Z15XHD/aZvQraSw9BpDU3EBcFnOVrw==", 152 | "requires": { 153 | "semver": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", 154 | "shimmer": "1.2.0" 155 | } 156 | }, 157 | "asynckit": { 158 | "version": "0.4.0", 159 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 160 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 161 | }, 162 | "aws-sign2": { 163 | "version": "0.7.0", 164 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 165 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 166 | }, 167 | "aws4": { 168 | "version": "1.6.0", 169 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", 170 | "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=" 171 | }, 172 | "balanced-match": { 173 | "version": "1.0.0", 174 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 175 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 176 | }, 177 | "base64url": { 178 | "version": "2.0.0", 179 | "resolved": "https://registry.npmjs.org/base64url/-/base64url-2.0.0.tgz", 180 | "integrity": "sha1-6sFuA+oUOO/5Qj1puqNiYu0fcLs=" 181 | }, 182 | "bcrypt": { 183 | "version": "1.0.3", 184 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-1.0.3.tgz", 185 | "integrity": "sha512-pRyDdo73C8Nim3jwFJ7DWe3TZCgwDfWZ6nHS5LSdU77kWbj1frruvdndP02AOavtD4y8v6Fp2dolbHgp4SDrfg==", 186 | "requires": { 187 | "nan": "2.6.2", 188 | "node-pre-gyp": "0.6.36" 189 | } 190 | }, 191 | "bcrypt-pbkdf": { 192 | "version": "1.0.1", 193 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", 194 | "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", 195 | "optional": true, 196 | "requires": { 197 | "tweetnacl": "0.14.5" 198 | } 199 | }, 200 | "binary-extensions": { 201 | "version": "1.11.0", 202 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz", 203 | "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=" 204 | }, 205 | "blessed": { 206 | "version": "0.1.81", 207 | "resolved": "https://registry.npmjs.org/blessed/-/blessed-0.1.81.tgz", 208 | "integrity": "sha1-+WLWh+wsNpVwrnGvhDJW5tDKESk=" 209 | }, 210 | "block-stream": { 211 | "version": "0.0.9", 212 | "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", 213 | "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", 214 | "requires": { 215 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz" 216 | } 217 | }, 218 | "body-parser": { 219 | "version": "https://registry.npmjs.org/body-parser/-/body-parser-1.17.1.tgz", 220 | "integrity": "sha1-dbO8mN3W5+DY/+dQ36ylxmmT+kc=", 221 | "requires": { 222 | "bytes": "https://registry.npmjs.org/bytes/-/bytes-2.4.0.tgz", 223 | "content-type": "https://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz", 224 | "debug": "https://registry.npmjs.org/debug/-/debug-2.6.1.tgz", 225 | "depd": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz", 226 | "http-errors": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.1.tgz", 227 | "iconv-lite": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.15.tgz", 228 | "on-finished": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 229 | "qs": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", 230 | "raw-body": "https://registry.npmjs.org/raw-body/-/raw-body-2.2.0.tgz", 231 | "type-is": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz" 232 | } 233 | }, 234 | "boom": { 235 | "version": "4.3.1", 236 | "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", 237 | "integrity": "sha1-T4owBctKfjiJ90kDD9JbluAdLjE=", 238 | "requires": { 239 | "hoek": "4.2.0" 240 | } 241 | }, 242 | "boxen": { 243 | "version": "1.3.0", 244 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.3.0.tgz", 245 | "integrity": "sha512-TNPjfTr432qx7yOjQyaXm3dSR0MH9vXp7eT1BFSl/C51g+EFnOR9hTg1IreahGBmDNCehscshe45f+C1TBZbLw==", 246 | "requires": { 247 | "ansi-align": "2.0.0", 248 | "camelcase": "4.1.0", 249 | "chalk": "2.3.0", 250 | "cli-boxes": "1.0.0", 251 | "string-width": "2.1.1", 252 | "term-size": "1.2.0", 253 | "widest-line": "2.0.0" 254 | } 255 | }, 256 | "brace-expansion": { 257 | "version": "1.1.8", 258 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 259 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 260 | "requires": { 261 | "balanced-match": "1.0.0", 262 | "concat-map": "0.0.1" 263 | } 264 | }, 265 | "braces": { 266 | "version": "1.8.5", 267 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 268 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 269 | "requires": { 270 | "expand-range": "1.8.2", 271 | "preserve": "0.2.0", 272 | "repeat-element": "1.1.2" 273 | } 274 | }, 275 | "buffer-equal-constant-time": { 276 | "version": "1.0.1", 277 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 278 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 279 | }, 280 | "buffer-shims": { 281 | "version": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz", 282 | "integrity": "sha1-mXjOMXOIxkmth5MCjDR37wRKi1E=" 283 | }, 284 | "bytes": { 285 | "version": "https://registry.npmjs.org/bytes/-/bytes-2.4.0.tgz", 286 | "integrity": "sha1-fZcZb51br39pNeJZhVSe3SpsIzk=" 287 | }, 288 | "camelcase": { 289 | "version": "4.1.0", 290 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 291 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=" 292 | }, 293 | "capture-stack-trace": { 294 | "version": "1.0.0", 295 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.0.tgz", 296 | "integrity": "sha1-Sm+gc5nCa7pH8LJJa00PtAjFVQ0=" 297 | }, 298 | "caseless": { 299 | "version": "0.12.0", 300 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 301 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 302 | }, 303 | "chalk": { 304 | "version": "2.3.0", 305 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 306 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 307 | "requires": { 308 | "ansi-styles": "3.2.0", 309 | "escape-string-regexp": "1.0.5", 310 | "supports-color": "4.5.0" 311 | } 312 | }, 313 | "charm": { 314 | "version": "0.1.2", 315 | "resolved": "https://registry.npmjs.org/charm/-/charm-0.1.2.tgz", 316 | "integrity": "sha1-BsIe7RobBq62dVPNxT4jJ0usIpY=" 317 | }, 318 | "chokidar": { 319 | "version": "1.7.0", 320 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", 321 | "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", 322 | "requires": { 323 | "anymatch": "1.3.2", 324 | "async-each": "1.0.1", 325 | "glob-parent": "2.0.0", 326 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 327 | "is-binary-path": "1.0.1", 328 | "is-glob": "2.0.1", 329 | "path-is-absolute": "1.0.1", 330 | "readdirp": "2.1.0" 331 | } 332 | }, 333 | "cli-boxes": { 334 | "version": "1.0.0", 335 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz", 336 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=" 337 | }, 338 | "cli-table-redemption": { 339 | "version": "1.0.1", 340 | "resolved": "https://registry.npmjs.org/cli-table-redemption/-/cli-table-redemption-1.0.1.tgz", 341 | "integrity": "sha512-SjVCciRyx01I4azo2K2rcc0NP/wOceXGzG1ZpYkEulbbIxDA/5YWv0oxG2HtQ4v8zPC6bgbRI7SbNaTZCxMNkg==", 342 | "requires": { 343 | "chalk": "1.1.3" 344 | }, 345 | "dependencies": { 346 | "ansi-regex": { 347 | "version": "2.1.1", 348 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 349 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 350 | }, 351 | "ansi-styles": { 352 | "version": "2.2.1", 353 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 354 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=" 355 | }, 356 | "chalk": { 357 | "version": "1.1.3", 358 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 359 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 360 | "requires": { 361 | "ansi-styles": "2.2.1", 362 | "escape-string-regexp": "1.0.5", 363 | "has-ansi": "2.0.0", 364 | "strip-ansi": "3.0.1", 365 | "supports-color": "2.0.0" 366 | } 367 | }, 368 | "strip-ansi": { 369 | "version": "3.0.1", 370 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 371 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 372 | "requires": { 373 | "ansi-regex": "2.1.1" 374 | } 375 | }, 376 | "supports-color": { 377 | "version": "2.0.0", 378 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 379 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=" 380 | } 381 | } 382 | }, 383 | "co": { 384 | "version": "4.6.0", 385 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 386 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" 387 | }, 388 | "code-point-at": { 389 | "version": "1.1.0", 390 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 391 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 392 | }, 393 | "color-convert": { 394 | "version": "1.9.1", 395 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.1.tgz", 396 | "integrity": "sha512-mjGanIiwQJskCC18rPR6OmrZ6fm2Lc7PeGFYwCmy5J34wC6F1PzdGL6xeMfmgicfYcNLGuVFA3WzXtIDCQSZxQ==", 397 | "requires": { 398 | "color-name": "1.1.3" 399 | } 400 | }, 401 | "color-name": { 402 | "version": "1.1.3", 403 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 404 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 405 | }, 406 | "combined-stream": { 407 | "version": "1.0.5", 408 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 409 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 410 | "requires": { 411 | "delayed-stream": "1.0.0" 412 | } 413 | }, 414 | "commander": { 415 | "version": "2.12.2", 416 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.12.2.tgz", 417 | "integrity": "sha512-BFnaq5ZOGcDN7FlrtBT4xxkgIToalIIxwjxLWVJ8bGTpe1LroqMiqQXdA7ygc7CRvaYS+9zfPGFnJqFSayx+AA==" 418 | }, 419 | "concat-map": { 420 | "version": "0.0.1", 421 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 422 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 423 | }, 424 | "configstore": { 425 | "version": "3.1.1", 426 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.1.tgz", 427 | "integrity": "sha512-5oNkD/L++l0O6xGXxb1EWS7SivtjfGQlRyxJsYgE0Z495/L81e2h4/d3r969hoPXuFItzNOKMtsXgYG4c7dYvw==", 428 | "requires": { 429 | "dot-prop": "4.2.0", 430 | "graceful-fs": "4.1.11", 431 | "make-dir": "1.1.0", 432 | "unique-string": "1.0.0", 433 | "write-file-atomic": "2.3.0", 434 | "xdg-basedir": "3.0.0" 435 | } 436 | }, 437 | "console-control-strings": { 438 | "version": "1.1.0", 439 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 440 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 441 | }, 442 | "content-disposition": { 443 | "version": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 444 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 445 | }, 446 | "content-type": { 447 | "version": "https://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz", 448 | "integrity": "sha1-t9ETrueo3Se9IRM8TcJSnfFyHu0=" 449 | }, 450 | "continuation-local-storage": { 451 | "version": "3.2.1", 452 | "resolved": "https://registry.npmjs.org/continuation-local-storage/-/continuation-local-storage-3.2.1.tgz", 453 | "integrity": "sha512-jx44cconVqkCEEyLSKWwkvUXwO561jXMa3LPjTPsm5QR22PA0/mhe33FT4Xb5y74JDvt/Cq+5lm8S8rskLv9ZA==", 454 | "requires": { 455 | "async-listener": "0.6.8", 456 | "emitter-listener": "1.1.1" 457 | } 458 | }, 459 | "cookie": { 460 | "version": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 461 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 462 | }, 463 | "cookie-signature": { 464 | "version": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 465 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 466 | }, 467 | "core-util-is": { 468 | "version": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 469 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 470 | }, 471 | "create-error-class": { 472 | "version": "3.0.2", 473 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz", 474 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=", 475 | "requires": { 476 | "capture-stack-trace": "1.0.0" 477 | } 478 | }, 479 | "cron": { 480 | "version": "1.3.0", 481 | "resolved": "https://registry.npmjs.org/cron/-/cron-1.3.0.tgz", 482 | "integrity": "sha512-K/SF7JlgMmNjcThWxkKvsHhey2EDB4CeOEWJ9aXWj3fbQJppsvTPIeyLdHfNq5IbbsMUUjRW1nr5dSO95f2E4w==", 483 | "requires": { 484 | "moment-timezone": "0.5.14" 485 | } 486 | }, 487 | "cron-parser": { 488 | "version": "2.4.3", 489 | "resolved": "https://registry.npmjs.org/cron-parser/-/cron-parser-2.4.3.tgz", 490 | "integrity": "sha512-IcAjsFKIF7C3zCIqRDs5sKMNtiyPuj07JN94LP4IjwaZYgKm/Tc4pihanHqJhq6FeqMp0SG0wUTb+LAmPqexAw==", 491 | "requires": { 492 | "is-nan": "1.2.1", 493 | "moment-timezone": "0.5.14" 494 | } 495 | }, 496 | "cross-spawn": { 497 | "version": "5.1.0", 498 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 499 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 500 | "requires": { 501 | "lru-cache": "4.1.1", 502 | "shebang-command": "1.2.0", 503 | "which": "1.3.0" 504 | } 505 | }, 506 | "cryptiles": { 507 | "version": "3.1.2", 508 | "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-3.1.2.tgz", 509 | "integrity": "sha1-qJ+7Ig9c4l7FboxKqKT9e1sNKf4=", 510 | "requires": { 511 | "boom": "5.2.0" 512 | }, 513 | "dependencies": { 514 | "boom": { 515 | "version": "5.2.0", 516 | "resolved": "https://registry.npmjs.org/boom/-/boom-5.2.0.tgz", 517 | "integrity": "sha512-Z5BTk6ZRe4tXXQlkqftmsAUANpXmuwlsF5Oov8ThoMbQRzdGTA1ngYRW160GexgOgjsFOKJz0LYhoNi+2AMBUw==", 518 | "requires": { 519 | "hoek": "4.2.0" 520 | } 521 | } 522 | } 523 | }, 524 | "crypto-random-string": { 525 | "version": "1.0.0", 526 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz", 527 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=" 528 | }, 529 | "dashdash": { 530 | "version": "1.14.1", 531 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 532 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 533 | "requires": { 534 | "assert-plus": "1.0.0" 535 | } 536 | }, 537 | "debug": { 538 | "version": "https://registry.npmjs.org/debug/-/debug-2.6.1.tgz", 539 | "integrity": "sha1-eYVQkLosTjEVzH2HaUkdWPBJE1E=", 540 | "requires": { 541 | "ms": "https://registry.npmjs.org/ms/-/ms-0.7.2.tgz" 542 | } 543 | }, 544 | "deep-extend": { 545 | "version": "0.4.2", 546 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.4.2.tgz", 547 | "integrity": "sha1-SLaZwn4zS/ifEIkr5DL25MfTSn8=" 548 | }, 549 | "define-properties": { 550 | "version": "1.1.2", 551 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz", 552 | "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=", 553 | "requires": { 554 | "foreach": "2.0.5", 555 | "object-keys": "1.0.11" 556 | } 557 | }, 558 | "delayed-stream": { 559 | "version": "1.0.0", 560 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 561 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 562 | }, 563 | "delegates": { 564 | "version": "1.0.0", 565 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 566 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 567 | }, 568 | "depd": { 569 | "version": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz", 570 | "integrity": "sha1-4b2Cxqq2ztlluXuIsX7T5SjKGMM=" 571 | }, 572 | "destroy": { 573 | "version": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 574 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 575 | }, 576 | "dot-prop": { 577 | "version": "4.2.0", 578 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", 579 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", 580 | "requires": { 581 | "is-obj": "1.0.1" 582 | } 583 | }, 584 | "duplexer": { 585 | "version": "0.1.1", 586 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", 587 | "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=" 588 | }, 589 | "duplexer3": { 590 | "version": "0.1.4", 591 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 592 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=" 593 | }, 594 | "ecc-jsbn": { 595 | "version": "0.1.1", 596 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", 597 | "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", 598 | "optional": true, 599 | "requires": { 600 | "jsbn": "0.1.1" 601 | } 602 | }, 603 | "ecdsa-sig-formatter": { 604 | "version": "1.0.9", 605 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.9.tgz", 606 | "integrity": "sha1-S8kmJ07Dtau1AW5+HWCSGsJisqE=", 607 | "requires": { 608 | "base64url": "2.0.0", 609 | "safe-buffer": "5.1.1" 610 | } 611 | }, 612 | "ee-first": { 613 | "version": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 614 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 615 | }, 616 | "emitter-listener": { 617 | "version": "1.1.1", 618 | "resolved": "https://registry.npmjs.org/emitter-listener/-/emitter-listener-1.1.1.tgz", 619 | "integrity": "sha1-6Lu+gkS8jg0LTvcc0UKUx/JBx+w=", 620 | "requires": { 621 | "shimmer": "1.2.0" 622 | } 623 | }, 624 | "encodeurl": { 625 | "version": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", 626 | "integrity": "sha1-eePVhlU0aQn+bw9Fpd5oEDspTSA=" 627 | }, 628 | "escape-html": { 629 | "version": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 630 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 631 | }, 632 | "escape-regexp": { 633 | "version": "0.0.1", 634 | "resolved": "https://registry.npmjs.org/escape-regexp/-/escape-regexp-0.0.1.tgz", 635 | "integrity": "sha1-9EvaEtRbvfnLf4Yu5+SCez3TIlQ=" 636 | }, 637 | "escape-string-regexp": { 638 | "version": "1.0.5", 639 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 640 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 641 | }, 642 | "etag": { 643 | "version": "https://registry.npmjs.org/etag/-/etag-1.8.0.tgz", 644 | "integrity": "sha1-b2Ma7zNtbEY2K1F2QETOIWvjwFE=" 645 | }, 646 | "event-stream": { 647 | "version": "3.3.4", 648 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 649 | "integrity": "sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=", 650 | "requires": { 651 | "duplexer": "0.1.1", 652 | "from": "0.1.7", 653 | "map-stream": "0.1.0", 654 | "pause-stream": "0.0.11", 655 | "split": "0.3.3", 656 | "stream-combiner": "0.0.4", 657 | "through": "2.3.8" 658 | } 659 | }, 660 | "eventemitter2": { 661 | "version": "1.0.5", 662 | "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-1.0.5.tgz", 663 | "integrity": "sha1-+YNhBRexc3wLncZDvsqTiTwE3xg=" 664 | }, 665 | "execa": { 666 | "version": "0.7.0", 667 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", 668 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", 669 | "requires": { 670 | "cross-spawn": "5.1.0", 671 | "get-stream": "3.0.0", 672 | "is-stream": "1.1.0", 673 | "npm-run-path": "2.0.2", 674 | "p-finally": "1.0.0", 675 | "signal-exit": "3.0.2", 676 | "strip-eof": "1.0.0" 677 | } 678 | }, 679 | "expand-brackets": { 680 | "version": "0.1.5", 681 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 682 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 683 | "requires": { 684 | "is-posix-bracket": "0.1.1" 685 | } 686 | }, 687 | "expand-range": { 688 | "version": "1.8.2", 689 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 690 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 691 | "requires": { 692 | "fill-range": "2.2.3" 693 | } 694 | }, 695 | "express": { 696 | "version": "https://registry.npmjs.org/express/-/express-4.15.2.tgz", 697 | "integrity": "sha1-rxB/wUhQRFfy3Kmm8lcdcSm5ezU=", 698 | "requires": { 699 | "accepts": "https://registry.npmjs.org/accepts/-/accepts-1.3.3.tgz", 700 | "array-flatten": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 701 | "content-disposition": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 702 | "content-type": "https://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz", 703 | "cookie": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 704 | "cookie-signature": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 705 | "debug": "https://registry.npmjs.org/debug/-/debug-2.6.1.tgz", 706 | "depd": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz", 707 | "encodeurl": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", 708 | "escape-html": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 709 | "etag": "https://registry.npmjs.org/etag/-/etag-1.8.0.tgz", 710 | "finalhandler": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.0.2.tgz", 711 | "fresh": "https://registry.npmjs.org/fresh/-/fresh-0.5.0.tgz", 712 | "merge-descriptors": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 713 | "methods": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 714 | "on-finished": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 715 | "parseurl": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", 716 | "path-to-regexp": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 717 | "proxy-addr": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.4.tgz", 718 | "qs": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", 719 | "range-parser": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 720 | "send": "https://registry.npmjs.org/send/-/send-0.15.1.tgz", 721 | "serve-static": "https://registry.npmjs.org/serve-static/-/serve-static-1.12.1.tgz", 722 | "setprototypeof": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 723 | "statuses": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 724 | "type-is": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz", 725 | "utils-merge": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", 726 | "vary": "https://registry.npmjs.org/vary/-/vary-1.1.1.tgz" 727 | } 728 | }, 729 | "extend": { 730 | "version": "3.0.1", 731 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 732 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=" 733 | }, 734 | "extglob": { 735 | "version": "0.3.2", 736 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 737 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 738 | "requires": { 739 | "is-extglob": "1.0.0" 740 | } 741 | }, 742 | "extsprintf": { 743 | "version": "1.3.0", 744 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 745 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 746 | }, 747 | "fast-deep-equal": { 748 | "version": "1.0.0", 749 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", 750 | "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=" 751 | }, 752 | "fast-json-stable-stringify": { 753 | "version": "2.0.0", 754 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 755 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 756 | }, 757 | "fclone": { 758 | "version": "1.0.11", 759 | "resolved": "https://registry.npmjs.org/fclone/-/fclone-1.0.11.tgz", 760 | "integrity": "sha1-EOhdo4v+p/xZk0HClu4ddyZu5kA=" 761 | }, 762 | "filename-regex": { 763 | "version": "2.0.1", 764 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 765 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=" 766 | }, 767 | "fill-range": { 768 | "version": "2.2.3", 769 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", 770 | "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", 771 | "requires": { 772 | "is-number": "2.1.0", 773 | "isobject": "2.1.0", 774 | "randomatic": "1.1.7", 775 | "repeat-element": "1.1.2", 776 | "repeat-string": "1.6.1" 777 | } 778 | }, 779 | "finalhandler": { 780 | "version": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.0.2.tgz", 781 | "integrity": "sha1-0ONvnbxVfy3hRCPfYmGInp1gyTo=", 782 | "requires": { 783 | "debug": "https://registry.npmjs.org/debug/-/debug-2.6.4.tgz", 784 | "encodeurl": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", 785 | "escape-html": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 786 | "on-finished": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 787 | "parseurl": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", 788 | "statuses": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 789 | "unpipe": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" 790 | }, 791 | "dependencies": { 792 | "debug": { 793 | "version": "https://registry.npmjs.org/debug/-/debug-2.6.4.tgz", 794 | "integrity": "sha1-dYaps8OXQcAoKuM0RcTorHRzT+A=", 795 | "requires": { 796 | "ms": "https://registry.npmjs.org/ms/-/ms-0.7.3.tgz" 797 | } 798 | }, 799 | "ms": { 800 | "version": "https://registry.npmjs.org/ms/-/ms-0.7.3.tgz", 801 | "integrity": "sha1-cIFVpeROM/X9D8U+gdDUCpG+H/8=" 802 | } 803 | } 804 | }, 805 | "for-in": { 806 | "version": "1.0.2", 807 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 808 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" 809 | }, 810 | "for-own": { 811 | "version": "0.1.5", 812 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 813 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 814 | "requires": { 815 | "for-in": "1.0.2" 816 | } 817 | }, 818 | "foreach": { 819 | "version": "2.0.5", 820 | "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz", 821 | "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=" 822 | }, 823 | "forever-agent": { 824 | "version": "0.6.1", 825 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 826 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 827 | }, 828 | "form-data": { 829 | "version": "2.3.1", 830 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", 831 | "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", 832 | "requires": { 833 | "asynckit": "0.4.0", 834 | "combined-stream": "1.0.5", 835 | "mime-types": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.15.tgz" 836 | } 837 | }, 838 | "forwarded": { 839 | "version": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.0.tgz", 840 | "integrity": "sha1-Ge+YdMSuHCl7zweP3mOgm2aoQ2M=" 841 | }, 842 | "fresh": { 843 | "version": "https://registry.npmjs.org/fresh/-/fresh-0.5.0.tgz", 844 | "integrity": "sha1-9HTKXmqSRtb9jglTz6m5yAWvp44=" 845 | }, 846 | "from": { 847 | "version": "0.1.7", 848 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 849 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=" 850 | }, 851 | "fs.realpath": { 852 | "version": "1.0.0", 853 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 854 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 855 | }, 856 | "fstream": { 857 | "version": "1.0.11", 858 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", 859 | "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", 860 | "requires": { 861 | "graceful-fs": "4.1.11", 862 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 863 | "mkdirp": "0.5.1", 864 | "rimraf": "2.6.2" 865 | } 866 | }, 867 | "fstream-ignore": { 868 | "version": "1.0.5", 869 | "resolved": "https://registry.npmjs.org/fstream-ignore/-/fstream-ignore-1.0.5.tgz", 870 | "integrity": "sha1-nDHa40dnAY/h0kmyTa2mfQktoQU=", 871 | "requires": { 872 | "fstream": "1.0.11", 873 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 874 | "minimatch": "3.0.4" 875 | } 876 | }, 877 | "gauge": { 878 | "version": "2.7.4", 879 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 880 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 881 | "requires": { 882 | "aproba": "1.2.0", 883 | "console-control-strings": "1.1.0", 884 | "has-unicode": "2.0.1", 885 | "object-assign": "4.1.1", 886 | "signal-exit": "3.0.2", 887 | "string-width": "1.0.2", 888 | "strip-ansi": "3.0.1", 889 | "wide-align": "1.1.2" 890 | }, 891 | "dependencies": { 892 | "ansi-regex": { 893 | "version": "2.1.1", 894 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 895 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 896 | }, 897 | "is-fullwidth-code-point": { 898 | "version": "1.0.0", 899 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 900 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 901 | "requires": { 902 | "number-is-nan": "1.0.1" 903 | } 904 | }, 905 | "string-width": { 906 | "version": "1.0.2", 907 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 908 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 909 | "requires": { 910 | "code-point-at": "1.1.0", 911 | "is-fullwidth-code-point": "1.0.0", 912 | "strip-ansi": "3.0.1" 913 | } 914 | }, 915 | "strip-ansi": { 916 | "version": "3.0.1", 917 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 918 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 919 | "requires": { 920 | "ansi-regex": "2.1.1" 921 | } 922 | } 923 | } 924 | }, 925 | "get-stream": { 926 | "version": "3.0.0", 927 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 928 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=" 929 | }, 930 | "getpass": { 931 | "version": "0.1.7", 932 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 933 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 934 | "requires": { 935 | "assert-plus": "1.0.0" 936 | } 937 | }, 938 | "gkt": { 939 | "version": "https://tgz.pm2.io/gkt-1.0.0.tgz", 940 | "integrity": "sha1-QFUCsAfzGcP0cXXER0UnMA8qta0=", 941 | "optional": true 942 | }, 943 | "glob": { 944 | "version": "7.1.2", 945 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 946 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 947 | "requires": { 948 | "fs.realpath": "1.0.0", 949 | "inflight": "1.0.6", 950 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 951 | "minimatch": "3.0.4", 952 | "once": "1.4.0", 953 | "path-is-absolute": "1.0.1" 954 | } 955 | }, 956 | "glob-base": { 957 | "version": "0.3.0", 958 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 959 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 960 | "requires": { 961 | "glob-parent": "2.0.0", 962 | "is-glob": "2.0.1" 963 | } 964 | }, 965 | "glob-parent": { 966 | "version": "2.0.0", 967 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 968 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 969 | "requires": { 970 | "is-glob": "2.0.1" 971 | } 972 | }, 973 | "global-dirs": { 974 | "version": "0.1.1", 975 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz", 976 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=", 977 | "requires": { 978 | "ini": "1.3.5" 979 | } 980 | }, 981 | "got": { 982 | "version": "6.7.1", 983 | "resolved": "https://registry.npmjs.org/got/-/got-6.7.1.tgz", 984 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=", 985 | "requires": { 986 | "create-error-class": "3.0.2", 987 | "duplexer3": "0.1.4", 988 | "get-stream": "3.0.0", 989 | "is-redirect": "1.0.0", 990 | "is-retry-allowed": "1.1.0", 991 | "is-stream": "1.1.0", 992 | "lowercase-keys": "1.0.0", 993 | "safe-buffer": "5.1.1", 994 | "timed-out": "4.0.1", 995 | "unzip-response": "2.0.1", 996 | "url-parse-lax": "1.0.0" 997 | } 998 | }, 999 | "graceful-fs": { 1000 | "version": "4.1.11", 1001 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 1002 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" 1003 | }, 1004 | "har-schema": { 1005 | "version": "2.0.0", 1006 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 1007 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 1008 | }, 1009 | "har-validator": { 1010 | "version": "5.0.3", 1011 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.0.3.tgz", 1012 | "integrity": "sha1-ukAsJmGU8VlW7xXg/PJCmT9qff0=", 1013 | "requires": { 1014 | "ajv": "5.5.0", 1015 | "har-schema": "2.0.0" 1016 | } 1017 | }, 1018 | "has-ansi": { 1019 | "version": "2.0.0", 1020 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 1021 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 1022 | "requires": { 1023 | "ansi-regex": "2.1.1" 1024 | }, 1025 | "dependencies": { 1026 | "ansi-regex": { 1027 | "version": "2.1.1", 1028 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 1029 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 1030 | } 1031 | } 1032 | }, 1033 | "has-flag": { 1034 | "version": "2.0.0", 1035 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 1036 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=" 1037 | }, 1038 | "has-unicode": { 1039 | "version": "2.0.1", 1040 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 1041 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 1042 | }, 1043 | "hawk": { 1044 | "version": "6.0.2", 1045 | "resolved": "https://registry.npmjs.org/hawk/-/hawk-6.0.2.tgz", 1046 | "integrity": "sha512-miowhl2+U7Qle4vdLqDdPt9m09K6yZhkLDTWGoUiUzrQCn+mHHSmfJgAyGaLRZbPmTqfFFjRV1QWCW0VWUJBbQ==", 1047 | "requires": { 1048 | "boom": "4.3.1", 1049 | "cryptiles": "3.1.2", 1050 | "hoek": "4.2.0", 1051 | "sntp": "2.1.0" 1052 | } 1053 | }, 1054 | "hoek": { 1055 | "version": "4.2.0", 1056 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.0.tgz", 1057 | "integrity": "sha512-v0XCLxICi9nPfYrS9RL8HbYnXi9obYAeLbSP00BmnZwCK9+Ih9WOjoZ8YoHCoav2csqn4FOz4Orldsy2dmDwmQ==" 1058 | }, 1059 | "http-errors": { 1060 | "version": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.1.tgz", 1061 | "integrity": "sha1-X4uO2YrKVFZWv1cplzh/kEpyIlc=", 1062 | "requires": { 1063 | "depd": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz", 1064 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1065 | "setprototypeof": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 1066 | "statuses": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz" 1067 | } 1068 | }, 1069 | "http-signature": { 1070 | "version": "1.2.0", 1071 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 1072 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 1073 | "requires": { 1074 | "assert-plus": "1.0.0", 1075 | "jsprim": "1.4.1", 1076 | "sshpk": "1.13.1" 1077 | } 1078 | }, 1079 | "iconv-lite": { 1080 | "version": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.15.tgz", 1081 | "integrity": "sha1-/iZaIYrGpXz+hUkn6dBMGYJe3es=" 1082 | }, 1083 | "ignore-by-default": { 1084 | "version": "1.0.1", 1085 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1086 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=" 1087 | }, 1088 | "import-lazy": { 1089 | "version": "2.1.0", 1090 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 1091 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=" 1092 | }, 1093 | "imurmurhash": { 1094 | "version": "0.1.4", 1095 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1096 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 1097 | }, 1098 | "inflight": { 1099 | "version": "1.0.6", 1100 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1101 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1102 | "requires": { 1103 | "once": "1.4.0", 1104 | "wrappy": "1.0.2" 1105 | } 1106 | }, 1107 | "inherits": { 1108 | "version": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1109 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1110 | }, 1111 | "ini": { 1112 | "version": "1.3.5", 1113 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1114 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 1115 | }, 1116 | "interpret": { 1117 | "version": "1.1.0", 1118 | "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.1.0.tgz", 1119 | "integrity": "sha1-ftGxQQxqDg94z5XTuEQMY/eLhhQ=" 1120 | }, 1121 | "ipaddr.js": { 1122 | "version": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.3.0.tgz", 1123 | "integrity": "sha1-HgOlL9rYOou7KyXL9JmLTP/NPew=" 1124 | }, 1125 | "is": { 1126 | "version": "3.2.1", 1127 | "resolved": "https://registry.npmjs.org/is/-/is-3.2.1.tgz", 1128 | "integrity": "sha1-0Kwq1V63sL7JJqUmb2xmKqqD3KU=" 1129 | }, 1130 | "is-binary-path": { 1131 | "version": "1.0.1", 1132 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 1133 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 1134 | "requires": { 1135 | "binary-extensions": "1.11.0" 1136 | } 1137 | }, 1138 | "is-buffer": { 1139 | "version": "1.1.6", 1140 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1141 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" 1142 | }, 1143 | "is-dotfile": { 1144 | "version": "1.0.3", 1145 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 1146 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=" 1147 | }, 1148 | "is-equal-shallow": { 1149 | "version": "0.1.3", 1150 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 1151 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 1152 | "requires": { 1153 | "is-primitive": "2.0.0" 1154 | } 1155 | }, 1156 | "is-extendable": { 1157 | "version": "0.1.1", 1158 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1159 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" 1160 | }, 1161 | "is-extglob": { 1162 | "version": "1.0.0", 1163 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1164 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=" 1165 | }, 1166 | "is-fullwidth-code-point": { 1167 | "version": "2.0.0", 1168 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1169 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 1170 | }, 1171 | "is-glob": { 1172 | "version": "2.0.1", 1173 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1174 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1175 | "requires": { 1176 | "is-extglob": "1.0.0" 1177 | } 1178 | }, 1179 | "is-installed-globally": { 1180 | "version": "0.1.0", 1181 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz", 1182 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=", 1183 | "requires": { 1184 | "global-dirs": "0.1.1", 1185 | "is-path-inside": "1.0.1" 1186 | } 1187 | }, 1188 | "is-nan": { 1189 | "version": "1.2.1", 1190 | "resolved": "https://registry.npmjs.org/is-nan/-/is-nan-1.2.1.tgz", 1191 | "integrity": "sha1-n69ltvttskt/XAYoR16nH5iEAeI=", 1192 | "requires": { 1193 | "define-properties": "1.1.2" 1194 | } 1195 | }, 1196 | "is-npm": { 1197 | "version": "1.0.0", 1198 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz", 1199 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=" 1200 | }, 1201 | "is-number": { 1202 | "version": "2.1.0", 1203 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 1204 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 1205 | "requires": { 1206 | "kind-of": "3.2.2" 1207 | } 1208 | }, 1209 | "is-obj": { 1210 | "version": "1.0.1", 1211 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1212 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=" 1213 | }, 1214 | "is-path-inside": { 1215 | "version": "1.0.1", 1216 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 1217 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 1218 | "requires": { 1219 | "path-is-inside": "1.0.2" 1220 | } 1221 | }, 1222 | "is-posix-bracket": { 1223 | "version": "0.1.1", 1224 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 1225 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=" 1226 | }, 1227 | "is-primitive": { 1228 | "version": "2.0.0", 1229 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 1230 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=" 1231 | }, 1232 | "is-redirect": { 1233 | "version": "1.0.0", 1234 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz", 1235 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=" 1236 | }, 1237 | "is-retry-allowed": { 1238 | "version": "1.1.0", 1239 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.1.0.tgz", 1240 | "integrity": "sha1-EaBgVotnM5REAz0BJaYaINVk+zQ=" 1241 | }, 1242 | "is-stream": { 1243 | "version": "1.1.0", 1244 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1245 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 1246 | }, 1247 | "is-typedarray": { 1248 | "version": "1.0.0", 1249 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1250 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 1251 | }, 1252 | "isarray": { 1253 | "version": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1254 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1255 | }, 1256 | "isexe": { 1257 | "version": "2.0.0", 1258 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1259 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 1260 | }, 1261 | "isobject": { 1262 | "version": "2.1.0", 1263 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 1264 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 1265 | "requires": { 1266 | "isarray": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz" 1267 | } 1268 | }, 1269 | "isstream": { 1270 | "version": "0.1.2", 1271 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1272 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 1273 | }, 1274 | "jsbn": { 1275 | "version": "0.1.1", 1276 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1277 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1278 | "optional": true 1279 | }, 1280 | "json-schema": { 1281 | "version": "0.2.3", 1282 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1283 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 1284 | }, 1285 | "json-schema-traverse": { 1286 | "version": "0.3.1", 1287 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 1288 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=" 1289 | }, 1290 | "json-stringify-safe": { 1291 | "version": "5.0.1", 1292 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1293 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 1294 | }, 1295 | "jsonwebtoken": { 1296 | "version": "8.1.0", 1297 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.1.0.tgz", 1298 | "integrity": "sha1-xjl80uX9WD1lwAeoPce7eOaYK4M=", 1299 | "requires": { 1300 | "jws": "3.1.4", 1301 | "lodash.includes": "4.3.0", 1302 | "lodash.isboolean": "3.0.3", 1303 | "lodash.isinteger": "4.0.4", 1304 | "lodash.isnumber": "3.0.3", 1305 | "lodash.isplainobject": "4.0.6", 1306 | "lodash.isstring": "4.0.1", 1307 | "lodash.once": "4.1.1", 1308 | "ms": "2.1.1", 1309 | "xtend": "4.0.1" 1310 | }, 1311 | "dependencies": { 1312 | "ms": { 1313 | "version": "2.1.1", 1314 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1315 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1316 | } 1317 | } 1318 | }, 1319 | "jsprim": { 1320 | "version": "1.4.1", 1321 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1322 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1323 | "requires": { 1324 | "assert-plus": "1.0.0", 1325 | "extsprintf": "1.3.0", 1326 | "json-schema": "0.2.3", 1327 | "verror": "1.10.0" 1328 | } 1329 | }, 1330 | "jwa": { 1331 | "version": "1.1.5", 1332 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.1.5.tgz", 1333 | "integrity": "sha1-oFUs4CIHQs1S4VN3SjKQXDDnVuU=", 1334 | "requires": { 1335 | "base64url": "2.0.0", 1336 | "buffer-equal-constant-time": "1.0.1", 1337 | "ecdsa-sig-formatter": "1.0.9", 1338 | "safe-buffer": "5.1.1" 1339 | } 1340 | }, 1341 | "jws": { 1342 | "version": "3.1.4", 1343 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.1.4.tgz", 1344 | "integrity": "sha1-+ei5M46KhHJ31kRLFGT2GIDgUKI=", 1345 | "requires": { 1346 | "base64url": "2.0.0", 1347 | "jwa": "1.1.5", 1348 | "safe-buffer": "5.1.1" 1349 | } 1350 | }, 1351 | "kind-of": { 1352 | "version": "3.2.2", 1353 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1354 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1355 | "requires": { 1356 | "is-buffer": "1.1.6" 1357 | } 1358 | }, 1359 | "latest-version": { 1360 | "version": "3.1.0", 1361 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz", 1362 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=", 1363 | "requires": { 1364 | "package-json": "4.0.1" 1365 | } 1366 | }, 1367 | "lazy": { 1368 | "version": "1.0.11", 1369 | "resolved": "https://registry.npmjs.org/lazy/-/lazy-1.0.11.tgz", 1370 | "integrity": "sha1-2qBoIGKCVCwIgojpdcKXwa53tpA=" 1371 | }, 1372 | "lodash": { 1373 | "version": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 1374 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" 1375 | }, 1376 | "lodash._baseassign": { 1377 | "version": "3.2.0", 1378 | "resolved": "https://registry.npmjs.org/lodash._baseassign/-/lodash._baseassign-3.2.0.tgz", 1379 | "integrity": "sha1-jDigmVAPIVrQnlnxci/QxSv+Ck4=", 1380 | "requires": { 1381 | "lodash._basecopy": "3.0.1", 1382 | "lodash.keys": "3.1.2" 1383 | } 1384 | }, 1385 | "lodash._basecopy": { 1386 | "version": "3.0.1", 1387 | "resolved": "https://registry.npmjs.org/lodash._basecopy/-/lodash._basecopy-3.0.1.tgz", 1388 | "integrity": "sha1-jaDmqHbPNEwK2KVIghEd08XHyjY=" 1389 | }, 1390 | "lodash._bindcallback": { 1391 | "version": "3.0.1", 1392 | "resolved": "https://registry.npmjs.org/lodash._bindcallback/-/lodash._bindcallback-3.0.1.tgz", 1393 | "integrity": "sha1-5THCdkTPi1epnhftlbNcdIeJOS4=" 1394 | }, 1395 | "lodash._createassigner": { 1396 | "version": "3.1.1", 1397 | "resolved": "https://registry.npmjs.org/lodash._createassigner/-/lodash._createassigner-3.1.1.tgz", 1398 | "integrity": "sha1-g4pbri/aymOsIt7o4Z+k5taXCxE=", 1399 | "requires": { 1400 | "lodash._bindcallback": "3.0.1", 1401 | "lodash._isiterateecall": "3.0.9", 1402 | "lodash.restparam": "3.6.1" 1403 | } 1404 | }, 1405 | "lodash._getnative": { 1406 | "version": "3.9.1", 1407 | "resolved": "https://registry.npmjs.org/lodash._getnative/-/lodash._getnative-3.9.1.tgz", 1408 | "integrity": "sha1-VwvH3t5G1hzc3mh9ZdPuy6o6r/U=" 1409 | }, 1410 | "lodash._isiterateecall": { 1411 | "version": "3.0.9", 1412 | "resolved": "https://registry.npmjs.org/lodash._isiterateecall/-/lodash._isiterateecall-3.0.9.tgz", 1413 | "integrity": "sha1-UgOte6Ql+uhCRg5pbbnPPmqsBXw=" 1414 | }, 1415 | "lodash.assign": { 1416 | "version": "3.2.0", 1417 | "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-3.2.0.tgz", 1418 | "integrity": "sha1-POnwI0tLIiPilrj6CsH+6OvKZPo=", 1419 | "requires": { 1420 | "lodash._baseassign": "3.2.0", 1421 | "lodash._createassigner": "3.1.1", 1422 | "lodash.keys": "3.1.2" 1423 | } 1424 | }, 1425 | "lodash.defaults": { 1426 | "version": "3.1.2", 1427 | "resolved": "https://registry.npmjs.org/lodash.defaults/-/lodash.defaults-3.1.2.tgz", 1428 | "integrity": "sha1-xzCLGNv4vJNy1wGnNJPGEZK9Liw=", 1429 | "requires": { 1430 | "lodash.assign": "3.2.0", 1431 | "lodash.restparam": "3.6.1" 1432 | } 1433 | }, 1434 | "lodash.findindex": { 1435 | "version": "4.6.0", 1436 | "resolved": "https://registry.npmjs.org/lodash.findindex/-/lodash.findindex-4.6.0.tgz", 1437 | "integrity": "sha1-oyRd7mH7m24GJLU1ElYku2nBEQY=" 1438 | }, 1439 | "lodash.includes": { 1440 | "version": "4.3.0", 1441 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1442 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1443 | }, 1444 | "lodash.isarguments": { 1445 | "version": "3.1.0", 1446 | "resolved": "https://registry.npmjs.org/lodash.isarguments/-/lodash.isarguments-3.1.0.tgz", 1447 | "integrity": "sha1-L1c9hcaiQon/AGY7SRwdM4/zRYo=" 1448 | }, 1449 | "lodash.isarray": { 1450 | "version": "3.0.4", 1451 | "resolved": "https://registry.npmjs.org/lodash.isarray/-/lodash.isarray-3.0.4.tgz", 1452 | "integrity": "sha1-eeTriMNqgSKvhvhEqpvNhRtfu1U=" 1453 | }, 1454 | "lodash.isboolean": { 1455 | "version": "3.0.3", 1456 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1457 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1458 | }, 1459 | "lodash.isequal": { 1460 | "version": "4.5.0", 1461 | "resolved": "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz", 1462 | "integrity": "sha1-QVxEePK8wwEgwizhDtMib30+GOA=" 1463 | }, 1464 | "lodash.isinteger": { 1465 | "version": "4.0.4", 1466 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1467 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1468 | }, 1469 | "lodash.isnumber": { 1470 | "version": "3.0.3", 1471 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1472 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1473 | }, 1474 | "lodash.isplainobject": { 1475 | "version": "4.0.6", 1476 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1477 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1478 | }, 1479 | "lodash.isstring": { 1480 | "version": "4.0.1", 1481 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1482 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1483 | }, 1484 | "lodash.keys": { 1485 | "version": "3.1.2", 1486 | "resolved": "https://registry.npmjs.org/lodash.keys/-/lodash.keys-3.1.2.tgz", 1487 | "integrity": "sha1-TbwEcrFWvlCgsoaFXRvQsMZWCYo=", 1488 | "requires": { 1489 | "lodash._getnative": "3.9.1", 1490 | "lodash.isarguments": "3.1.0", 1491 | "lodash.isarray": "3.0.4" 1492 | } 1493 | }, 1494 | "lodash.merge": { 1495 | "version": "4.6.0", 1496 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.0.tgz", 1497 | "integrity": "sha1-aYhLoUSsM/5plzemCG3v+t0PicU=" 1498 | }, 1499 | "lodash.once": { 1500 | "version": "4.1.1", 1501 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1502 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1503 | }, 1504 | "lodash.restparam": { 1505 | "version": "3.6.1", 1506 | "resolved": "https://registry.npmjs.org/lodash.restparam/-/lodash.restparam-3.6.1.tgz", 1507 | "integrity": "sha1-k2pOMJ7zMKdkXtQUWYbIWuWyCAU=" 1508 | }, 1509 | "long-timeout": { 1510 | "version": "0.1.1", 1511 | "resolved": "https://registry.npmjs.org/long-timeout/-/long-timeout-0.1.1.tgz", 1512 | "integrity": "sha1-lyHXiLR+C8taJMLivuGg2lXatRQ=" 1513 | }, 1514 | "lowercase-keys": { 1515 | "version": "1.0.0", 1516 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.0.tgz", 1517 | "integrity": "sha1-TjNms55/VFfjXxMkvfb4jQv8cwY=" 1518 | }, 1519 | "lru-cache": { 1520 | "version": "4.1.1", 1521 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", 1522 | "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", 1523 | "requires": { 1524 | "pseudomap": "1.0.2", 1525 | "yallist": "2.1.2" 1526 | } 1527 | }, 1528 | "make-dir": { 1529 | "version": "1.1.0", 1530 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.1.0.tgz", 1531 | "integrity": "sha512-0Pkui4wLJ7rxvmfUvs87skoEaxmu0hCUApF8nonzpl7q//FWp9zu8W61Scz4sd/kUiqDxvUhtoam2efDyiBzcA==", 1532 | "requires": { 1533 | "pify": "3.0.0" 1534 | } 1535 | }, 1536 | "map-stream": { 1537 | "version": "0.1.0", 1538 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 1539 | "integrity": "sha1-5WqpTEyAVaFkBKBnS3jyFffI4ZQ=" 1540 | }, 1541 | "media-typer": { 1542 | "version": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1543 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1544 | }, 1545 | "merge-descriptors": { 1546 | "version": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1547 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1548 | }, 1549 | "methods": { 1550 | "version": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1551 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1552 | }, 1553 | "micromatch": { 1554 | "version": "2.3.11", 1555 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 1556 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 1557 | "requires": { 1558 | "arr-diff": "2.0.0", 1559 | "array-unique": "0.2.1", 1560 | "braces": "1.8.5", 1561 | "expand-brackets": "0.1.5", 1562 | "extglob": "0.3.2", 1563 | "filename-regex": "2.0.1", 1564 | "is-extglob": "1.0.0", 1565 | "is-glob": "2.0.1", 1566 | "kind-of": "3.2.2", 1567 | "normalize-path": "2.1.1", 1568 | "object.omit": "2.0.1", 1569 | "parse-glob": "3.0.4", 1570 | "regex-cache": "0.4.4" 1571 | } 1572 | }, 1573 | "mime": { 1574 | "version": "https://registry.npmjs.org/mime/-/mime-1.3.4.tgz", 1575 | "integrity": "sha1-EV+eO2s9rylZmDyzjxSaLUDrXVM=" 1576 | }, 1577 | "mime-db": { 1578 | "version": "https://registry.npmjs.org/mime-db/-/mime-db-1.27.0.tgz", 1579 | "integrity": "sha1-gg9XIpa70g7CXtVeW13oaeVDbrE=" 1580 | }, 1581 | "mime-types": { 1582 | "version": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.15.tgz", 1583 | "integrity": "sha1-pOv1BkCUVpI3uM9wBGd20J/JKu0=", 1584 | "requires": { 1585 | "mime-db": "https://registry.npmjs.org/mime-db/-/mime-db-1.27.0.tgz" 1586 | } 1587 | }, 1588 | "minimatch": { 1589 | "version": "3.0.4", 1590 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1591 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1592 | "requires": { 1593 | "brace-expansion": "1.1.8" 1594 | } 1595 | }, 1596 | "minimist": { 1597 | "version": "1.2.0", 1598 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1599 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" 1600 | }, 1601 | "mkdirp": { 1602 | "version": "0.5.1", 1603 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1604 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1605 | "requires": { 1606 | "minimist": "0.0.8" 1607 | }, 1608 | "dependencies": { 1609 | "minimist": { 1610 | "version": "0.0.8", 1611 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1612 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 1613 | } 1614 | } 1615 | }, 1616 | "moment": { 1617 | "version": "2.20.1", 1618 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.20.1.tgz", 1619 | "integrity": "sha512-Yh9y73JRljxW5QxN08Fner68eFLxM5ynNOAw2LbIB1YAGeQzZT8QFSUvkAz609Zf+IHhhaUxqZK8dG3W/+HEvg==" 1620 | }, 1621 | "moment-timezone": { 1622 | "version": "0.5.14", 1623 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.14.tgz", 1624 | "integrity": "sha1-TrOP+VOLgBCLpGekWPPtQmjM/LE=", 1625 | "requires": { 1626 | "moment": "2.20.1" 1627 | } 1628 | }, 1629 | "ms": { 1630 | "version": "https://registry.npmjs.org/ms/-/ms-0.7.2.tgz", 1631 | "integrity": "sha1-riXPJRKziFodldfwN4aNhDESR2U=" 1632 | }, 1633 | "mute-stream": { 1634 | "version": "0.0.7", 1635 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1636 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=" 1637 | }, 1638 | "nan": { 1639 | "version": "2.6.2", 1640 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.6.2.tgz", 1641 | "integrity": "sha1-5P805slf37WuzAjeZZb0NgWn20U=" 1642 | }, 1643 | "needle": { 1644 | "version": "1.6.0", 1645 | "resolved": "https://registry.npmjs.org/needle/-/needle-1.6.0.tgz", 1646 | "integrity": "sha1-9SpYWJchIWGOAC+OY4TK2sItYk8=", 1647 | "requires": { 1648 | "debug": "https://registry.npmjs.org/debug/-/debug-2.6.1.tgz", 1649 | "iconv-lite": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.15.tgz" 1650 | } 1651 | }, 1652 | "negotiator": { 1653 | "version": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1654 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 1655 | }, 1656 | "node-pre-gyp": { 1657 | "version": "0.6.36", 1658 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.6.36.tgz", 1659 | "integrity": "sha1-22BBEst04NR3VU6bUFsXq936t4Y=", 1660 | "requires": { 1661 | "mkdirp": "0.5.1", 1662 | "nopt": "4.0.1", 1663 | "npmlog": "4.1.2", 1664 | "rc": "1.2.2", 1665 | "request": "2.83.0", 1666 | "rimraf": "2.6.2", 1667 | "semver": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", 1668 | "tar": "2.2.1", 1669 | "tar-pack": "3.4.1" 1670 | }, 1671 | "dependencies": { 1672 | "nopt": { 1673 | "version": "4.0.1", 1674 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", 1675 | "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", 1676 | "requires": { 1677 | "abbrev": "1.1.1", 1678 | "osenv": "0.1.4" 1679 | } 1680 | } 1681 | } 1682 | }, 1683 | "node-schedule": { 1684 | "version": "1.3.0", 1685 | "resolved": "https://registry.npmjs.org/node-schedule/-/node-schedule-1.3.0.tgz", 1686 | "integrity": "sha512-NNwO9SUPjBwFmPh3vXiPVEhJLn4uqYmZYvJV358SRGM06BR4UoIqxJpeJwDDXB6atULsgQA97MfD1zMd5xsu+A==", 1687 | "requires": { 1688 | "cron-parser": "2.4.3", 1689 | "long-timeout": "0.1.1", 1690 | "sorted-array-functions": "1.1.0" 1691 | } 1692 | }, 1693 | "nodemailer": { 1694 | "version": "4.4.1", 1695 | "resolved": "https://registry.npmjs.org/nodemailer/-/nodemailer-4.4.1.tgz", 1696 | "integrity": "sha512-1bnszJJXatcHJhLpxQ1XMkLDjCjPKvGKMtRQ73FOsoNln3UQjddEQmz6fAwM3aj0GtQ3dQX9qtMHPelz63GU7A==" 1697 | }, 1698 | "nodemon": { 1699 | "version": "1.13.3", 1700 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.13.3.tgz", 1701 | "integrity": "sha512-JTDI4il69J3rQ5aXQdNcDZDfk8JXC2c5Uh9zjTtFGrlP72UDoOEPB7reDMjo27tbLhtxtPAfGwhs28RVMz5rHQ==", 1702 | "requires": { 1703 | "@remy/pstree": "1.1.0", 1704 | "chokidar": "1.7.0", 1705 | "debug": "2.6.9", 1706 | "es6-promise": "3.3.1", 1707 | "ignore-by-default": "1.0.1", 1708 | "lodash.defaults": "3.1.2", 1709 | "minimatch": "3.0.4", 1710 | "touch": "3.1.0", 1711 | "undefsafe": "0.0.3", 1712 | "update-notifier": "2.3.0" 1713 | }, 1714 | "dependencies": { 1715 | "debug": { 1716 | "version": "2.6.9", 1717 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1718 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1719 | "requires": { 1720 | "ms": "2.0.0" 1721 | } 1722 | }, 1723 | "es6-promise": { 1724 | "version": "3.3.1", 1725 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz", 1726 | "integrity": "sha1-oIzd6EzNvzTQJ6FFG8kdS80ophM=" 1727 | }, 1728 | "ms": { 1729 | "version": "2.0.0", 1730 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1731 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1732 | } 1733 | } 1734 | }, 1735 | "nopt": { 1736 | "version": "1.0.10", 1737 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1738 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1739 | "requires": { 1740 | "abbrev": "1.1.1" 1741 | } 1742 | }, 1743 | "normalize-path": { 1744 | "version": "2.1.1", 1745 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1746 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1747 | "requires": { 1748 | "remove-trailing-separator": "1.1.0" 1749 | } 1750 | }, 1751 | "npm-run-path": { 1752 | "version": "2.0.2", 1753 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1754 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1755 | "requires": { 1756 | "path-key": "2.0.1" 1757 | } 1758 | }, 1759 | "npmlog": { 1760 | "version": "4.1.2", 1761 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1762 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1763 | "requires": { 1764 | "are-we-there-yet": "1.1.4", 1765 | "console-control-strings": "1.1.0", 1766 | "gauge": "2.7.4", 1767 | "set-blocking": "2.0.0" 1768 | } 1769 | }, 1770 | "nssocket": { 1771 | "version": "0.6.0", 1772 | "resolved": "https://registry.npmjs.org/nssocket/-/nssocket-0.6.0.tgz", 1773 | "integrity": "sha1-Wflvb/MhVm8zxw99vu7N/cBxVPo=", 1774 | "requires": { 1775 | "eventemitter2": "0.4.14", 1776 | "lazy": "1.0.11" 1777 | }, 1778 | "dependencies": { 1779 | "eventemitter2": { 1780 | "version": "0.4.14", 1781 | "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-0.4.14.tgz", 1782 | "integrity": "sha1-j2G3XN4BKy6esoTUVFWDtWQ7Yas=" 1783 | } 1784 | } 1785 | }, 1786 | "number-is-nan": { 1787 | "version": "1.0.1", 1788 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1789 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1790 | }, 1791 | "oauth-sign": { 1792 | "version": "0.8.2", 1793 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", 1794 | "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=" 1795 | }, 1796 | "object-assign": { 1797 | "version": "4.1.1", 1798 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1799 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1800 | }, 1801 | "object-keys": { 1802 | "version": "1.0.11", 1803 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz", 1804 | "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=" 1805 | }, 1806 | "object.omit": { 1807 | "version": "2.0.1", 1808 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 1809 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 1810 | "requires": { 1811 | "for-own": "0.1.5", 1812 | "is-extendable": "0.1.1" 1813 | } 1814 | }, 1815 | "on-finished": { 1816 | "version": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1817 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1818 | "requires": { 1819 | "ee-first": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz" 1820 | } 1821 | }, 1822 | "once": { 1823 | "version": "1.4.0", 1824 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1825 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1826 | "requires": { 1827 | "wrappy": "1.0.2" 1828 | } 1829 | }, 1830 | "os-homedir": { 1831 | "version": "1.0.2", 1832 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1833 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1834 | }, 1835 | "os-tmpdir": { 1836 | "version": "1.0.2", 1837 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1838 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1839 | }, 1840 | "osenv": { 1841 | "version": "0.1.4", 1842 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.4.tgz", 1843 | "integrity": "sha1-Qv5tWVPfBsgGS+bxdsPQWqqjRkQ=", 1844 | "requires": { 1845 | "os-homedir": "1.0.2", 1846 | "os-tmpdir": "1.0.2" 1847 | } 1848 | }, 1849 | "p-finally": { 1850 | "version": "1.0.0", 1851 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1852 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" 1853 | }, 1854 | "package-json": { 1855 | "version": "4.0.1", 1856 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz", 1857 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=", 1858 | "requires": { 1859 | "got": "6.7.1", 1860 | "registry-auth-token": "3.3.1", 1861 | "registry-url": "3.1.0", 1862 | "semver": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz" 1863 | } 1864 | }, 1865 | "parse-glob": { 1866 | "version": "3.0.4", 1867 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 1868 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 1869 | "requires": { 1870 | "glob-base": "0.3.0", 1871 | "is-dotfile": "1.0.3", 1872 | "is-extglob": "1.0.0", 1873 | "is-glob": "2.0.1" 1874 | } 1875 | }, 1876 | "parseurl": { 1877 | "version": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", 1878 | "integrity": "sha1-yKuMkiO6NIiKpkopeyiFO+wY2lY=" 1879 | }, 1880 | "path-is-absolute": { 1881 | "version": "1.0.1", 1882 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1883 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1884 | }, 1885 | "path-is-inside": { 1886 | "version": "1.0.2", 1887 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1888 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=" 1889 | }, 1890 | "path-key": { 1891 | "version": "2.0.1", 1892 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1893 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 1894 | }, 1895 | "path-parse": { 1896 | "version": "1.0.5", 1897 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", 1898 | "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=" 1899 | }, 1900 | "path-to-regexp": { 1901 | "version": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1902 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1903 | }, 1904 | "pause-stream": { 1905 | "version": "0.0.11", 1906 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1907 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 1908 | "requires": { 1909 | "through": "2.3.8" 1910 | } 1911 | }, 1912 | "performance-now": { 1913 | "version": "2.1.0", 1914 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1915 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 1916 | }, 1917 | "pidusage": { 1918 | "version": "1.2.0", 1919 | "resolved": "https://registry.npmjs.org/pidusage/-/pidusage-1.2.0.tgz", 1920 | "integrity": "sha512-OGo+iSOk44HRJ8q15AyG570UYxcm5u+R99DI8Khu8P3tKGkVu5EZX4ywHglWSTMNNXQ274oeGpYrvFEhDIFGPg==" 1921 | }, 1922 | "pify": { 1923 | "version": "3.0.0", 1924 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1925 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" 1926 | }, 1927 | "pm2": { 1928 | "version": "2.9.1", 1929 | "resolved": "https://registry.npmjs.org/pm2/-/pm2-2.9.1.tgz", 1930 | "integrity": "sha512-y6Wwo/jdBxIWPzZQFmuwxsrCG4nhaq+yEArULMDD8N68q/FErvMgn25P5CmzoYz/ZeT7lIyU1gHTdx3uNFF1VA==", 1931 | "requires": { 1932 | "async": "2.6.0", 1933 | "blessed": "0.1.81", 1934 | "chalk": "1.1.3", 1935 | "chokidar": "1.7.0", 1936 | "cli-table-redemption": "1.0.1", 1937 | "commander": "2.12.2", 1938 | "cron": "1.3.0", 1939 | "debug": "3.1.0", 1940 | "eventemitter2": "1.0.5", 1941 | "fclone": "1.0.11", 1942 | "gkt": "https://tgz.pm2.io/gkt-1.0.0.tgz", 1943 | "mkdirp": "0.5.1", 1944 | "moment": "2.20.1", 1945 | "needle": "1.6.0", 1946 | "nssocket": "0.6.0", 1947 | "pidusage": "1.2.0", 1948 | "pm2-axon": "3.1.0", 1949 | "pm2-axon-rpc": "0.5.0", 1950 | "pm2-deploy": "0.3.9", 1951 | "pm2-multimeter": "0.1.2", 1952 | "pmx": "1.5.5", 1953 | "promptly": "2.2.0", 1954 | "semver": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", 1955 | "shelljs": "0.7.8", 1956 | "source-map-support": "0.5.0", 1957 | "sprintf-js": "1.1.1", 1958 | "vizion": "0.2.13", 1959 | "yamljs": "0.3.0" 1960 | }, 1961 | "dependencies": { 1962 | "ansi-regex": { 1963 | "version": "2.1.1", 1964 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 1965 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 1966 | }, 1967 | "ansi-styles": { 1968 | "version": "2.2.1", 1969 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 1970 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=" 1971 | }, 1972 | "async": { 1973 | "version": "2.6.0", 1974 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.0.tgz", 1975 | "integrity": "sha512-xAfGg1/NTLBBKlHFmnd7PlmUW9KhVQIUuSrYem9xzFUZy13ScvtyGGejaae9iAVRiRq9+Cx7DPFaAAhCpyxyPw==", 1976 | "requires": { 1977 | "lodash": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz" 1978 | } 1979 | }, 1980 | "chalk": { 1981 | "version": "1.1.3", 1982 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 1983 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 1984 | "requires": { 1985 | "ansi-styles": "2.2.1", 1986 | "escape-string-regexp": "1.0.5", 1987 | "has-ansi": "2.0.0", 1988 | "strip-ansi": "3.0.1", 1989 | "supports-color": "2.0.0" 1990 | } 1991 | }, 1992 | "debug": { 1993 | "version": "3.1.0", 1994 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1995 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1996 | "requires": { 1997 | "ms": "2.0.0" 1998 | } 1999 | }, 2000 | "ms": { 2001 | "version": "2.0.0", 2002 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2003 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2004 | }, 2005 | "strip-ansi": { 2006 | "version": "3.0.1", 2007 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2008 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2009 | "requires": { 2010 | "ansi-regex": "2.1.1" 2011 | } 2012 | }, 2013 | "supports-color": { 2014 | "version": "2.0.0", 2015 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 2016 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=" 2017 | } 2018 | } 2019 | }, 2020 | "pm2-axon": { 2021 | "version": "3.1.0", 2022 | "resolved": "https://registry.npmjs.org/pm2-axon/-/pm2-axon-3.1.0.tgz", 2023 | "integrity": "sha512-5sBM+vHw0Cp2K9CJ9ZOYhKtNCCcgQ0eKOyFrSo5Jusbq9FfvuelsMG4WDaxkqosaQbf8N5YfyHhD7eOUcnm5rQ==", 2024 | "requires": { 2025 | "amp": "0.3.1", 2026 | "amp-message": "0.1.2", 2027 | "debug": "3.1.0", 2028 | "escape-regexp": "0.0.1" 2029 | }, 2030 | "dependencies": { 2031 | "debug": { 2032 | "version": "3.1.0", 2033 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2034 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2035 | "requires": { 2036 | "ms": "2.0.0" 2037 | } 2038 | }, 2039 | "ms": { 2040 | "version": "2.0.0", 2041 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2042 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2043 | } 2044 | } 2045 | }, 2046 | "pm2-axon-rpc": { 2047 | "version": "0.5.0", 2048 | "resolved": "https://registry.npmjs.org/pm2-axon-rpc/-/pm2-axon-rpc-0.5.0.tgz", 2049 | "integrity": "sha512-jKiAlnIitx+TtJ1++jThmN49gM0Dte4gm27Kqu2xAUQn33Rh9+5lOOqShS5Xbp0RPZL42hKNEgaVVOSqm3sJCg==", 2050 | "requires": { 2051 | "debug": "3.1.0", 2052 | "fclone": "1.0.11" 2053 | }, 2054 | "dependencies": { 2055 | "debug": { 2056 | "version": "3.1.0", 2057 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2058 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2059 | "requires": { 2060 | "ms": "2.0.0" 2061 | } 2062 | }, 2063 | "ms": { 2064 | "version": "2.0.0", 2065 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2066 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2067 | } 2068 | } 2069 | }, 2070 | "pm2-deploy": { 2071 | "version": "0.3.9", 2072 | "resolved": "https://registry.npmjs.org/pm2-deploy/-/pm2-deploy-0.3.9.tgz", 2073 | "integrity": "sha512-IYF45fPwfLE27BivrtodK7zzN56BNDErK7brcldIHjVIHLlk+cdhijq3kwTkPPP3Tpc3H2C942QGRgjg0hHajA==", 2074 | "requires": { 2075 | "async": "1.5.2", 2076 | "tv4": "1.3.0" 2077 | }, 2078 | "dependencies": { 2079 | "async": { 2080 | "version": "1.5.2", 2081 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 2082 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=" 2083 | } 2084 | } 2085 | }, 2086 | "pm2-multimeter": { 2087 | "version": "0.1.2", 2088 | "resolved": "https://registry.npmjs.org/pm2-multimeter/-/pm2-multimeter-0.1.2.tgz", 2089 | "integrity": "sha1-Gh5VFT1BoFU0zqI8/oYKuqDrSs4=", 2090 | "requires": { 2091 | "charm": "0.1.2" 2092 | } 2093 | }, 2094 | "pmx": { 2095 | "version": "1.5.5", 2096 | "resolved": "https://registry.npmjs.org/pmx/-/pmx-1.5.5.tgz", 2097 | "integrity": "sha1-tuC4V27c9Y1/QGlntE2z2nfjV/A=", 2098 | "requires": { 2099 | "debug": "3.1.0", 2100 | "json-stringify-safe": "5.0.1", 2101 | "vxx": "1.2.2" 2102 | }, 2103 | "dependencies": { 2104 | "debug": { 2105 | "version": "3.1.0", 2106 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2107 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2108 | "requires": { 2109 | "ms": "2.0.0" 2110 | } 2111 | }, 2112 | "ms": { 2113 | "version": "2.0.0", 2114 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2115 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2116 | } 2117 | } 2118 | }, 2119 | "prepend-http": { 2120 | "version": "1.0.4", 2121 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", 2122 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=" 2123 | }, 2124 | "preserve": { 2125 | "version": "0.2.0", 2126 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 2127 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=" 2128 | }, 2129 | "process-nextick-args": { 2130 | "version": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 2131 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" 2132 | }, 2133 | "promptly": { 2134 | "version": "2.2.0", 2135 | "resolved": "https://registry.npmjs.org/promptly/-/promptly-2.2.0.tgz", 2136 | "integrity": "sha1-KhP6BjaIoqWYOxYf/wEIoH0m/HQ=", 2137 | "requires": { 2138 | "read": "1.0.7" 2139 | } 2140 | }, 2141 | "proxy-addr": { 2142 | "version": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.4.tgz", 2143 | "integrity": "sha1-J+VF9pYKRKYn2bREZ+NcG2tM4vM=", 2144 | "requires": { 2145 | "forwarded": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.0.tgz", 2146 | "ipaddr.js": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.3.0.tgz" 2147 | } 2148 | }, 2149 | "ps-tree": { 2150 | "version": "1.1.0", 2151 | "resolved": "https://registry.npmjs.org/ps-tree/-/ps-tree-1.1.0.tgz", 2152 | "integrity": "sha1-tCGyQUDWID8e08dplrRCewjowBQ=", 2153 | "requires": { 2154 | "event-stream": "3.3.4" 2155 | } 2156 | }, 2157 | "pseudomap": { 2158 | "version": "1.0.2", 2159 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2160 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 2161 | }, 2162 | "punycode": { 2163 | "version": "1.4.1", 2164 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 2165 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 2166 | }, 2167 | "qs": { 2168 | "version": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", 2169 | "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=" 2170 | }, 2171 | "randomatic": { 2172 | "version": "1.1.7", 2173 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", 2174 | "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", 2175 | "requires": { 2176 | "is-number": "3.0.0", 2177 | "kind-of": "4.0.0" 2178 | }, 2179 | "dependencies": { 2180 | "is-number": { 2181 | "version": "3.0.0", 2182 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 2183 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 2184 | "requires": { 2185 | "kind-of": "3.2.2" 2186 | }, 2187 | "dependencies": { 2188 | "kind-of": { 2189 | "version": "3.2.2", 2190 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2191 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2192 | "requires": { 2193 | "is-buffer": "1.1.6" 2194 | } 2195 | } 2196 | } 2197 | }, 2198 | "kind-of": { 2199 | "version": "4.0.0", 2200 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 2201 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 2202 | "requires": { 2203 | "is-buffer": "1.1.6" 2204 | } 2205 | } 2206 | } 2207 | }, 2208 | "range-parser": { 2209 | "version": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 2210 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 2211 | }, 2212 | "raw-body": { 2213 | "version": "https://registry.npmjs.org/raw-body/-/raw-body-2.2.0.tgz", 2214 | "integrity": "sha1-mUl2z2pQlqQRYoQEkvC9xdbn+5Y=", 2215 | "requires": { 2216 | "bytes": "https://registry.npmjs.org/bytes/-/bytes-2.4.0.tgz", 2217 | "iconv-lite": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.15.tgz", 2218 | "unpipe": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" 2219 | } 2220 | }, 2221 | "rc": { 2222 | "version": "1.2.2", 2223 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.2.tgz", 2224 | "integrity": "sha1-2M6ctX6NZNnHut2YdsfDTL48cHc=", 2225 | "requires": { 2226 | "deep-extend": "0.4.2", 2227 | "ini": "1.3.5", 2228 | "minimist": "1.2.0", 2229 | "strip-json-comments": "2.0.1" 2230 | } 2231 | }, 2232 | "read": { 2233 | "version": "1.0.7", 2234 | "resolved": "https://registry.npmjs.org/read/-/read-1.0.7.tgz", 2235 | "integrity": "sha1-s9oZvQUkMal2cdRKQmNK33ELQMQ=", 2236 | "requires": { 2237 | "mute-stream": "0.0.7" 2238 | } 2239 | }, 2240 | "readable-stream": { 2241 | "version": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz", 2242 | "integrity": "sha1-BwV6y+JGeyIELTb5jFrVBwVOlbE=", 2243 | "requires": { 2244 | "buffer-shims": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz", 2245 | "core-util-is": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 2246 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 2247 | "isarray": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2248 | "process-nextick-args": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 2249 | "string_decoder": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.0.tgz", 2250 | "util-deprecate": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz" 2251 | } 2252 | }, 2253 | "readdirp": { 2254 | "version": "2.1.0", 2255 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", 2256 | "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", 2257 | "requires": { 2258 | "graceful-fs": "4.1.11", 2259 | "minimatch": "3.0.4", 2260 | "readable-stream": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz", 2261 | "set-immediate-shim": "1.0.1" 2262 | } 2263 | }, 2264 | "rechoir": { 2265 | "version": "0.6.2", 2266 | "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", 2267 | "integrity": "sha1-hSBLVNuoLVdC4oyWdW70OvUOM4Q=", 2268 | "requires": { 2269 | "resolve": "1.5.0" 2270 | } 2271 | }, 2272 | "regex-cache": { 2273 | "version": "0.4.4", 2274 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 2275 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 2276 | "requires": { 2277 | "is-equal-shallow": "0.1.3" 2278 | } 2279 | }, 2280 | "registry-auth-token": { 2281 | "version": "3.3.1", 2282 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.3.1.tgz", 2283 | "integrity": "sha1-+w0yie4Nmtosu1KvXf5mywcNMAY=", 2284 | "requires": { 2285 | "rc": "1.2.2", 2286 | "safe-buffer": "5.1.1" 2287 | } 2288 | }, 2289 | "registry-url": { 2290 | "version": "3.1.0", 2291 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz", 2292 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=", 2293 | "requires": { 2294 | "rc": "1.2.2" 2295 | } 2296 | }, 2297 | "remove-trailing-separator": { 2298 | "version": "1.1.0", 2299 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2300 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=" 2301 | }, 2302 | "repeat-element": { 2303 | "version": "1.1.2", 2304 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 2305 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=" 2306 | }, 2307 | "repeat-string": { 2308 | "version": "1.6.1", 2309 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2310 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" 2311 | }, 2312 | "request": { 2313 | "version": "2.83.0", 2314 | "resolved": "https://registry.npmjs.org/request/-/request-2.83.0.tgz", 2315 | "integrity": "sha512-lR3gD69osqm6EYLk9wB/G1W/laGWjzH90t1vEa2xuxHD5KUrSzp9pUSfTm+YC5Nxt2T8nMPEvKlhbQayU7bgFw==", 2316 | "requires": { 2317 | "aws-sign2": "0.7.0", 2318 | "aws4": "1.6.0", 2319 | "caseless": "0.12.0", 2320 | "combined-stream": "1.0.5", 2321 | "extend": "3.0.1", 2322 | "forever-agent": "0.6.1", 2323 | "form-data": "2.3.1", 2324 | "har-validator": "5.0.3", 2325 | "hawk": "6.0.2", 2326 | "http-signature": "1.2.0", 2327 | "is-typedarray": "1.0.0", 2328 | "isstream": "0.1.2", 2329 | "json-stringify-safe": "5.0.1", 2330 | "mime-types": "2.1.17", 2331 | "oauth-sign": "0.8.2", 2332 | "performance-now": "2.1.0", 2333 | "qs": "6.5.1", 2334 | "safe-buffer": "5.1.1", 2335 | "stringstream": "0.0.5", 2336 | "tough-cookie": "2.3.3", 2337 | "tunnel-agent": "0.6.0", 2338 | "uuid": "3.1.0" 2339 | }, 2340 | "dependencies": { 2341 | "mime-db": { 2342 | "version": "1.30.0", 2343 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", 2344 | "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=" 2345 | }, 2346 | "mime-types": { 2347 | "version": "2.1.17", 2348 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", 2349 | "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", 2350 | "requires": { 2351 | "mime-db": "1.30.0" 2352 | } 2353 | }, 2354 | "qs": { 2355 | "version": "6.5.1", 2356 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 2357 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 2358 | } 2359 | } 2360 | }, 2361 | "resolve": { 2362 | "version": "1.5.0", 2363 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.5.0.tgz", 2364 | "integrity": "sha512-hgoSGrc3pjzAPHNBg+KnFcK2HwlHTs/YrAGUr6qgTVUZmXv1UEXXl0bZNBKMA9fud6lRYFdPGz0xXxycPzmmiw==", 2365 | "requires": { 2366 | "path-parse": "1.0.5" 2367 | } 2368 | }, 2369 | "rimraf": { 2370 | "version": "2.6.2", 2371 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 2372 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 2373 | "requires": { 2374 | "glob": "7.1.2" 2375 | } 2376 | }, 2377 | "safe-buffer": { 2378 | "version": "5.1.1", 2379 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 2380 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 2381 | }, 2382 | "semver": { 2383 | "version": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", 2384 | "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=" 2385 | }, 2386 | "semver-diff": { 2387 | "version": "2.1.0", 2388 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz", 2389 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=", 2390 | "requires": { 2391 | "semver": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz" 2392 | } 2393 | }, 2394 | "send": { 2395 | "version": "https://registry.npmjs.org/send/-/send-0.15.1.tgz", 2396 | "integrity": "sha1-igI1TCbm9cynAAZfXwzeupDse18=", 2397 | "requires": { 2398 | "debug": "https://registry.npmjs.org/debug/-/debug-2.6.1.tgz", 2399 | "depd": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz", 2400 | "destroy": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 2401 | "encodeurl": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", 2402 | "escape-html": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2403 | "etag": "https://registry.npmjs.org/etag/-/etag-1.8.0.tgz", 2404 | "fresh": "https://registry.npmjs.org/fresh/-/fresh-0.5.0.tgz", 2405 | "http-errors": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.1.tgz", 2406 | "mime": "https://registry.npmjs.org/mime/-/mime-1.3.4.tgz", 2407 | "ms": "https://registry.npmjs.org/ms/-/ms-0.7.2.tgz", 2408 | "on-finished": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2409 | "range-parser": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 2410 | "statuses": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz" 2411 | } 2412 | }, 2413 | "serve-static": { 2414 | "version": "https://registry.npmjs.org/serve-static/-/serve-static-1.12.1.tgz", 2415 | "integrity": "sha1-dEOpZePO1kes61Y5+ga/TRu+ADk=", 2416 | "requires": { 2417 | "encodeurl": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", 2418 | "escape-html": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2419 | "parseurl": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", 2420 | "send": "https://registry.npmjs.org/send/-/send-0.15.1.tgz" 2421 | } 2422 | }, 2423 | "set-blocking": { 2424 | "version": "2.0.0", 2425 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2426 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 2427 | }, 2428 | "set-immediate-shim": { 2429 | "version": "1.0.1", 2430 | "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", 2431 | "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=" 2432 | }, 2433 | "setprototypeof": { 2434 | "version": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 2435 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 2436 | }, 2437 | "shebang-command": { 2438 | "version": "1.2.0", 2439 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2440 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2441 | "requires": { 2442 | "shebang-regex": "1.0.0" 2443 | } 2444 | }, 2445 | "shebang-regex": { 2446 | "version": "1.0.0", 2447 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2448 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 2449 | }, 2450 | "shelljs": { 2451 | "version": "0.7.8", 2452 | "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.7.8.tgz", 2453 | "integrity": "sha1-3svPh0sNHl+3LhSxZKloMEjprLM=", 2454 | "requires": { 2455 | "glob": "7.1.2", 2456 | "interpret": "1.1.0", 2457 | "rechoir": "0.6.2" 2458 | } 2459 | }, 2460 | "shimmer": { 2461 | "version": "1.2.0", 2462 | "resolved": "https://registry.npmjs.org/shimmer/-/shimmer-1.2.0.tgz", 2463 | "integrity": "sha512-xTCx2vohXC2EWWDqY/zb4+5Mu28D+HYNSOuFzsyRDRvI/e1ICb69afwaUwfjr+25ZXldbOLyp+iDUZHq8UnTag==" 2464 | }, 2465 | "signal-exit": { 2466 | "version": "3.0.2", 2467 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2468 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 2469 | }, 2470 | "sntp": { 2471 | "version": "2.1.0", 2472 | "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.1.0.tgz", 2473 | "integrity": "sha512-FL1b58BDrqS3A11lJ0zEdnJ3UOKqVxawAkF3k7F0CVN7VQ34aZrV+G8BZ1WC9ZL7NyrwsW0oviwsWDgRuVYtJg==", 2474 | "requires": { 2475 | "hoek": "4.2.0" 2476 | } 2477 | }, 2478 | "sorted-array-functions": { 2479 | "version": "1.1.0", 2480 | "resolved": "https://registry.npmjs.org/sorted-array-functions/-/sorted-array-functions-1.1.0.tgz", 2481 | "integrity": "sha512-zq6fLdGQixb9VZfT/tLgU+LzoedJyTbcf1I/TKETFeUVoWIfcs5HNr+SJSvQJLXRlEZjB1gpILTrxamxAdCcgA==" 2482 | }, 2483 | "source-map": { 2484 | "version": "0.6.1", 2485 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2486 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" 2487 | }, 2488 | "source-map-support": { 2489 | "version": "0.5.0", 2490 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.0.tgz", 2491 | "integrity": "sha512-vUoN3I7fHQe0R/SJLKRdKYuEdRGogsviXFkHHo17AWaTGv17VLnxw+CFXvqy+y4ORZ3doWLQcxRYfwKrsd/H7Q==", 2492 | "requires": { 2493 | "source-map": "0.6.1" 2494 | } 2495 | }, 2496 | "split": { 2497 | "version": "0.3.3", 2498 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 2499 | "integrity": "sha1-zQ7qXmOiEd//frDwkcQTPi0N0o8=", 2500 | "requires": { 2501 | "through": "2.3.8" 2502 | } 2503 | }, 2504 | "sprintf-js": { 2505 | "version": "1.1.1", 2506 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.1.tgz", 2507 | "integrity": "sha1-Nr54Mgr+WAH2zqPueLblqrlA6gw=" 2508 | }, 2509 | "sshpk": { 2510 | "version": "1.13.1", 2511 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", 2512 | "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", 2513 | "requires": { 2514 | "asn1": "0.2.3", 2515 | "assert-plus": "1.0.0", 2516 | "bcrypt-pbkdf": "1.0.1", 2517 | "dashdash": "1.14.1", 2518 | "ecc-jsbn": "0.1.1", 2519 | "getpass": "0.1.7", 2520 | "jsbn": "0.1.1", 2521 | "tweetnacl": "0.14.5" 2522 | } 2523 | }, 2524 | "statuses": { 2525 | "version": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 2526 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 2527 | }, 2528 | "stream-combiner": { 2529 | "version": "0.0.4", 2530 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 2531 | "integrity": "sha1-TV5DPBhSYd3mI8o/RMWGvPXErRQ=", 2532 | "requires": { 2533 | "duplexer": "0.1.1" 2534 | } 2535 | }, 2536 | "string_decoder": { 2537 | "version": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.0.tgz", 2538 | "integrity": "sha1-8G9BFXtmTYYGn4S9vcmw2KsoFmc=", 2539 | "requires": { 2540 | "buffer-shims": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz" 2541 | } 2542 | }, 2543 | "string-width": { 2544 | "version": "2.1.1", 2545 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2546 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2547 | "requires": { 2548 | "is-fullwidth-code-point": "2.0.0", 2549 | "strip-ansi": "4.0.0" 2550 | } 2551 | }, 2552 | "stringstream": { 2553 | "version": "0.0.5", 2554 | "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", 2555 | "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=" 2556 | }, 2557 | "strip-ansi": { 2558 | "version": "4.0.0", 2559 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2560 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2561 | "requires": { 2562 | "ansi-regex": "3.0.0" 2563 | } 2564 | }, 2565 | "strip-eof": { 2566 | "version": "1.0.0", 2567 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 2568 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" 2569 | }, 2570 | "strip-json-comments": { 2571 | "version": "2.0.1", 2572 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2573 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 2574 | }, 2575 | "supports-color": { 2576 | "version": "4.5.0", 2577 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 2578 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 2579 | "requires": { 2580 | "has-flag": "2.0.0" 2581 | } 2582 | }, 2583 | "tar": { 2584 | "version": "2.2.1", 2585 | "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", 2586 | "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", 2587 | "requires": { 2588 | "block-stream": "0.0.9", 2589 | "fstream": "1.0.11", 2590 | "inherits": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz" 2591 | } 2592 | }, 2593 | "tar-pack": { 2594 | "version": "3.4.1", 2595 | "resolved": "https://registry.npmjs.org/tar-pack/-/tar-pack-3.4.1.tgz", 2596 | "integrity": "sha512-PPRybI9+jM5tjtCbN2cxmmRU7YmqT3Zv/UDy48tAh2XRkLa9bAORtSWLkVc13+GJF+cdTh1yEnHEk3cpTaL5Kg==", 2597 | "requires": { 2598 | "debug": "https://registry.npmjs.org/debug/-/debug-2.6.1.tgz", 2599 | "fstream": "1.0.11", 2600 | "fstream-ignore": "1.0.5", 2601 | "once": "1.4.0", 2602 | "readable-stream": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz", 2603 | "rimraf": "2.6.2", 2604 | "tar": "2.2.1", 2605 | "uid-number": "0.0.6" 2606 | } 2607 | }, 2608 | "term-size": { 2609 | "version": "1.2.0", 2610 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz", 2611 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=", 2612 | "requires": { 2613 | "execa": "0.7.0" 2614 | } 2615 | }, 2616 | "through": { 2617 | "version": "2.3.8", 2618 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2619 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 2620 | }, 2621 | "timed-out": { 2622 | "version": "4.0.1", 2623 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz", 2624 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=" 2625 | }, 2626 | "touch": { 2627 | "version": "3.1.0", 2628 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2629 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2630 | "requires": { 2631 | "nopt": "1.0.10" 2632 | } 2633 | }, 2634 | "tough-cookie": { 2635 | "version": "2.3.3", 2636 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.3.tgz", 2637 | "integrity": "sha1-C2GKVWW23qkL80JdBNVe3EdadWE=", 2638 | "requires": { 2639 | "punycode": "1.4.1" 2640 | } 2641 | }, 2642 | "tunnel-agent": { 2643 | "version": "0.6.0", 2644 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 2645 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 2646 | "requires": { 2647 | "safe-buffer": "5.1.1" 2648 | } 2649 | }, 2650 | "tv4": { 2651 | "version": "1.3.0", 2652 | "resolved": "https://registry.npmjs.org/tv4/-/tv4-1.3.0.tgz", 2653 | "integrity": "sha1-0CDIRvrdUMhVq7JeuuzGj8EPeWM=" 2654 | }, 2655 | "tweetnacl": { 2656 | "version": "0.14.5", 2657 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 2658 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 2659 | "optional": true 2660 | }, 2661 | "type-is": { 2662 | "version": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz", 2663 | "integrity": "sha1-yrEPtJCeRByChC6v4a1kbIGARBA=", 2664 | "requires": { 2665 | "media-typer": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2666 | "mime-types": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.15.tgz" 2667 | } 2668 | }, 2669 | "uid-number": { 2670 | "version": "0.0.6", 2671 | "resolved": "https://registry.npmjs.org/uid-number/-/uid-number-0.0.6.tgz", 2672 | "integrity": "sha1-DqEOgDXo61uOREnwbaHHMGY7qoE=" 2673 | }, 2674 | "undefsafe": { 2675 | "version": "0.0.3", 2676 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-0.0.3.tgz", 2677 | "integrity": "sha1-7Mo6A+VrmvFzhbqsgSrIO5lKli8=" 2678 | }, 2679 | "unique-string": { 2680 | "version": "1.0.0", 2681 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz", 2682 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=", 2683 | "requires": { 2684 | "crypto-random-string": "1.0.0" 2685 | } 2686 | }, 2687 | "unpipe": { 2688 | "version": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2689 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2690 | }, 2691 | "unzip-response": { 2692 | "version": "2.0.1", 2693 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz", 2694 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=" 2695 | }, 2696 | "update-notifier": { 2697 | "version": "2.3.0", 2698 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.3.0.tgz", 2699 | "integrity": "sha1-TognpruRUUCrCTVZ1wFOPruDdFE=", 2700 | "requires": { 2701 | "boxen": "1.3.0", 2702 | "chalk": "2.3.0", 2703 | "configstore": "3.1.1", 2704 | "import-lazy": "2.1.0", 2705 | "is-installed-globally": "0.1.0", 2706 | "is-npm": "1.0.0", 2707 | "latest-version": "3.1.0", 2708 | "semver-diff": "2.1.0", 2709 | "xdg-basedir": "3.0.0" 2710 | } 2711 | }, 2712 | "url-parse-lax": { 2713 | "version": "1.0.0", 2714 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz", 2715 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=", 2716 | "requires": { 2717 | "prepend-http": "1.0.4" 2718 | } 2719 | }, 2720 | "util-deprecate": { 2721 | "version": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2722 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2723 | }, 2724 | "utils-merge": { 2725 | "version": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", 2726 | "integrity": "sha1-ApT7kiu5N1FTVBxPcJYjHyh8ivg=" 2727 | }, 2728 | "uuid": { 2729 | "version": "3.1.0", 2730 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 2731 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 2732 | }, 2733 | "vary": { 2734 | "version": "https://registry.npmjs.org/vary/-/vary-1.1.1.tgz", 2735 | "integrity": "sha1-Z1Neu2lMHVIldFeYRmUyP1h+jTc=" 2736 | }, 2737 | "verror": { 2738 | "version": "1.10.0", 2739 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2740 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2741 | "requires": { 2742 | "assert-plus": "1.0.0", 2743 | "core-util-is": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 2744 | "extsprintf": "1.3.0" 2745 | } 2746 | }, 2747 | "vizion": { 2748 | "version": "0.2.13", 2749 | "resolved": "https://registry.npmjs.org/vizion/-/vizion-0.2.13.tgz", 2750 | "integrity": "sha1-ExTN7is0EW+fWxJIU2+V2/zW718=", 2751 | "requires": { 2752 | "async": "1.5.2" 2753 | }, 2754 | "dependencies": { 2755 | "async": { 2756 | "version": "1.5.2", 2757 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 2758 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=" 2759 | } 2760 | } 2761 | }, 2762 | "vxx": { 2763 | "version": "1.2.2", 2764 | "resolved": "https://registry.npmjs.org/vxx/-/vxx-1.2.2.tgz", 2765 | "integrity": "sha1-dB+1HG8R0zg9pvm5IBil17qAdhE=", 2766 | "requires": { 2767 | "continuation-local-storage": "3.2.1", 2768 | "debug": "2.6.9", 2769 | "extend": "3.0.1", 2770 | "is": "3.2.1", 2771 | "lodash.findindex": "4.6.0", 2772 | "lodash.isequal": "4.5.0", 2773 | "lodash.merge": "4.6.0", 2774 | "methods": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2775 | "semver": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", 2776 | "shimmer": "1.2.0", 2777 | "uuid": "3.1.0" 2778 | }, 2779 | "dependencies": { 2780 | "debug": { 2781 | "version": "2.6.9", 2782 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2783 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2784 | "requires": { 2785 | "ms": "2.0.0" 2786 | } 2787 | }, 2788 | "ms": { 2789 | "version": "2.0.0", 2790 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2791 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2792 | } 2793 | } 2794 | }, 2795 | "which": { 2796 | "version": "1.3.0", 2797 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 2798 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 2799 | "requires": { 2800 | "isexe": "2.0.0" 2801 | } 2802 | }, 2803 | "wide-align": { 2804 | "version": "1.1.2", 2805 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.2.tgz", 2806 | "integrity": "sha512-ijDLlyQ7s6x1JgCLur53osjm/UXUYD9+0PbYKrBsYisYXzCxN+HC3mYDNy/dWdmf3AwqwU3CXwDCvsNgGK1S0w==", 2807 | "requires": { 2808 | "string-width": "1.0.2" 2809 | }, 2810 | "dependencies": { 2811 | "ansi-regex": { 2812 | "version": "2.1.1", 2813 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 2814 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 2815 | }, 2816 | "is-fullwidth-code-point": { 2817 | "version": "1.0.0", 2818 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 2819 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 2820 | "requires": { 2821 | "number-is-nan": "1.0.1" 2822 | } 2823 | }, 2824 | "string-width": { 2825 | "version": "1.0.2", 2826 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 2827 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 2828 | "requires": { 2829 | "code-point-at": "1.1.0", 2830 | "is-fullwidth-code-point": "1.0.0", 2831 | "strip-ansi": "3.0.1" 2832 | } 2833 | }, 2834 | "strip-ansi": { 2835 | "version": "3.0.1", 2836 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2837 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2838 | "requires": { 2839 | "ansi-regex": "2.1.1" 2840 | } 2841 | } 2842 | } 2843 | }, 2844 | "widest-line": { 2845 | "version": "2.0.0", 2846 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-2.0.0.tgz", 2847 | "integrity": "sha1-AUKk6KJD+IgsAjOqDgKBqnYVInM=", 2848 | "requires": { 2849 | "string-width": "2.1.1" 2850 | } 2851 | }, 2852 | "wrappy": { 2853 | "version": "1.0.2", 2854 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2855 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2856 | }, 2857 | "write-file-atomic": { 2858 | "version": "2.3.0", 2859 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.3.0.tgz", 2860 | "integrity": "sha512-xuPeK4OdjWqtfi59ylvVL0Yn35SF3zgcAcv7rBPFHVaEapaDr4GdGgm3j7ckTwH9wHL7fGmgfAnb0+THrHb8tA==", 2861 | "requires": { 2862 | "graceful-fs": "4.1.11", 2863 | "imurmurhash": "0.1.4", 2864 | "signal-exit": "3.0.2" 2865 | } 2866 | }, 2867 | "xdg-basedir": { 2868 | "version": "3.0.0", 2869 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz", 2870 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=" 2871 | }, 2872 | "xtend": { 2873 | "version": "4.0.1", 2874 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2875 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" 2876 | }, 2877 | "yallist": { 2878 | "version": "2.1.2", 2879 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 2880 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 2881 | }, 2882 | "yamljs": { 2883 | "version": "0.3.0", 2884 | "resolved": "https://registry.npmjs.org/yamljs/-/yamljs-0.3.0.tgz", 2885 | "integrity": "sha512-C/FsVVhht4iPQYXOInoxUM/1ELSf9EsgKH34FofQOp6hwCPrW4vG4w5++TED3xRUo8gD7l0P1J1dLlDYzODsTQ==", 2886 | "requires": { 2887 | "argparse": "1.0.9", 2888 | "glob": "7.1.2" 2889 | } 2890 | } 2891 | } 2892 | } 2893 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "node-mysql-boilerplate", 3 | "version": "1.0.7", 4 | "description": "node-mysql-boilerplate", 5 | "main": "app.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "node app.js" 9 | }, 10 | "dependencies": { 11 | "ajv": "^5.5.0", 12 | "bcrypt": "^1.0.3", 13 | "bcryptjs": "*", 14 | "body-parser": "*", 15 | "cors": "*", 16 | "express": "*", 17 | "jsonwebtoken": "^8.1.0", 18 | "node-schedule": "^1.3.0", 19 | "nodemailer": "^4.4.1", 20 | "nodemon": "^1.13.3", 21 | "pm2": "^2.9.1" 22 | }, 23 | "author": "", 24 | "license": "ISC" 25 | } 26 | -------------------------------------------------------------------------------- /public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Node-Mysql package 8 | 9 | 10 |

hello you are boom

11 | 12 | -------------------------------------------------------------------------------- /web.config: -------------------------------------------------------------------------------- 1 | 2 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 59 | 60 | 61 | --------------------------------------------------------------------------------