├── .gitignore ├── LICENSE ├── README.md ├── app.js ├── bin └── www ├── config └── config.js ├── controllers ├── company.controller.js ├── home.controller.js └── user.controller.js ├── example.env ├── middleware ├── custom.js └── passport.js ├── migrations ├── 20180116184151-create-user.js ├── 20180118191116-create-company.js ├── 20180118191640-create-kiosk-group.js ├── 20180118191702-create-kiosk.js ├── 20180118191729-create-catalog.js ├── 20180118191738-create-category.js └── 20180118191804-create-product.js ├── models ├── company.model.js ├── index.js └── user.model.js ├── package-lock.json ├── package.json ├── public └── v1 │ └── documentation │ ├── README.md │ ├── api.json │ └── dist │ ├── favicon-16x16.png │ ├── favicon-32x32.png │ ├── index.html │ ├── oauth2-redirect.html │ ├── swagger-ui-bundle.js │ ├── swagger-ui-bundle.js.map │ ├── swagger-ui-standalone-preset.js │ ├── swagger-ui-standalone-preset.js.map │ ├── swagger-ui.css │ ├── swagger-ui.css.map │ ├── swagger-ui.js │ └── swagger-ui.js.map ├── routes └── v1.js └── services ├── auth.service.js └── util.service.js /.gitignore: -------------------------------------------------------------------------------- 1 | **/node_modules 2 | .env 3 | .DS_Store 4 | .idea -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 Brian Alois(Schardt) 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 | # Rest Api Node and Mysql 2 | 3 | ## Note: Please look at this new tempalate that uses nest, and graphql. It is much more up to date as I do not use this template anymore 4 | https://github.com/brianschardt/node_nest_graphql_template 5 | 6 | ## Description 7 | This is an Restful API for Node.js and Mysql. Designed after PHP's beautiful Laravel. This is in the MVC format, 8 | except because it is an API there are no views, just models and controllers. 9 | 10 | tutorial can be found here: https://medium.com/@brianalois/build-a-rest-api-for-node-mysql-2018-jwt-6957bcfc7ac9 11 | ##### Routing : Express 12 | ##### ORM Database : Sequelize 13 | ##### Authentication : Passport, JWT 14 | 15 | ## Installation 16 | 17 | #### Download Code | Clone the Repo 18 | 19 | ``` 20 | git clone {repo_name} 21 | ``` 22 | 23 | #### Install Node Modules 24 | ``` 25 | npm install 26 | ``` 27 | 28 | #### Create .env File 29 | You will find a example.env file in the home directory. Paste the contents of that into a file named .env in the same directory. 30 | Fill in the variables to fit your application 31 | 32 | -------------------------------------------------------------------------------- /app.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const logger = require('morgan'); 3 | const bodyParser = require('body-parser'); 4 | const passport = require('passport'); 5 | const pe = require('parse-error'); 6 | const cors = require('cors'); 7 | 8 | const v1 = require('./routes/v1'); 9 | const app = express(); 10 | 11 | const CONFIG = require('./config/config'); 12 | 13 | app.use(logger('dev')); 14 | app.use(bodyParser.json()); 15 | app.use(bodyParser.urlencoded({ extended: false })); 16 | // app.use(cookieParser()); 17 | // app.use(express.static(path.join(__dirname, 'public'))); 18 | 19 | //Passport 20 | app.use(passport.initialize()); 21 | 22 | //Log Env 23 | console.log("Environment:", CONFIG.app) 24 | //DATABASE 25 | const models = require("./models"); 26 | models.sequelize.authenticate().then(() => { 27 | console.log('Connected to SQL database:', CONFIG.db_name); 28 | }) 29 | .catch(err => { 30 | console.error('Unable to connect to SQL database:',CONFIG.db_name, err); 31 | }); 32 | if(CONFIG.app==='dev'){ 33 | models.sequelize.sync();//creates table if they do not already exist 34 | // models.sequelize.sync({ force: true });//deletes all tables then recreates them useful for testing and development purposes 35 | } 36 | // CORS 37 | app.use(cors()); 38 | 39 | app.use('/v1', v1); 40 | 41 | app.use('/', function(req, res){ 42 | res.statusCode = 200;//send the appropriate status code 43 | res.json({status:"success", message:"Parcel Pending API", data:{}}) 44 | }); 45 | 46 | // catch 404 and forward to error handler 47 | app.use(function(req, res, next) { 48 | var err = new Error('Not Found'); 49 | err.status = 404; 50 | next(err); 51 | }); 52 | 53 | // error handler 54 | app.use(function(err, req, res, next) { 55 | // set locals, only providing error in development 56 | res.locals.message = err.message; 57 | res.locals.error = req.app.get('env') === 'development' ? err : {}; 58 | 59 | // render the error page 60 | res.status(err.status || 500); 61 | res.render('error'); 62 | }); 63 | 64 | module.exports = app; 65 | 66 | //This is here to handle all the uncaught promise rejections 67 | process.on('unhandledRejection', error => { 68 | console.error('Uncaught Error', pe(error)); 69 | }); -------------------------------------------------------------------------------- /bin/www: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | /** 4 | * Module dependencies. 5 | */ 6 | 7 | const app = require('../app'); 8 | const debug = require('debug')('server:server'); 9 | const http = require('http'); 10 | const CONFIG = require('../config/config'); 11 | /** 12 | * Get port from environment and store in Express. 13 | */ 14 | 15 | const port = normalizePort(CONFIG.port || '3000'); 16 | app.set('port', port); 17 | 18 | /** 19 | * Create HTTP server. 20 | */ 21 | 22 | const server = http.createServer(app); 23 | 24 | /** 25 | * Listen on provided port, on all network interfaces. 26 | */ 27 | 28 | server.listen(port); 29 | server.on('error', onError); 30 | server.on('listening', onListening); 31 | 32 | /** 33 | * Normalize a port into a number, string, or false. 34 | */ 35 | 36 | function normalizePort(val) { 37 | const port = parseInt(val, 10); 38 | 39 | if (isNaN(port)) { 40 | // named pipe 41 | return val; 42 | } 43 | 44 | if (port >= 0) { 45 | // port number 46 | return port; 47 | } 48 | 49 | return false; 50 | } 51 | 52 | /** 53 | * Event listener for HTTP server "error" event. 54 | */ 55 | 56 | function onError(error) { 57 | if (error.syscall !== 'listen') { 58 | throw error; 59 | } 60 | 61 | const bind = typeof port === 'string' 62 | ? 'Pipe ' + port 63 | : 'Port ' + port; 64 | 65 | // handle specific listen errors with friendly messages 66 | switch (error.code) { 67 | case 'EACCES': 68 | console.error(bind + ' requires elevated privileges'); 69 | process.exit(1); 70 | break; 71 | case 'EADDRINUSE': 72 | console.error(bind + ' is already in use'); 73 | process.exit(1); 74 | break; 75 | default: 76 | throw error; 77 | } 78 | } 79 | 80 | /** 81 | * Event listener for HTTP server "listening" event. 82 | */ 83 | 84 | function onListening() { 85 | const addr = server.address(); 86 | const bind = typeof addr === 'string' 87 | ? 'pipe ' + addr 88 | : 'port ' + addr.port; 89 | debug('Listening on ' + bind); 90 | 91 | console.log('Server listenning on port:', addr.port); 92 | 93 | } 94 | -------------------------------------------------------------------------------- /config/config.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config();//instatiate environment variables 2 | 3 | let CONFIG = {} //Make this global to use all over the application 4 | 5 | CONFIG.app = process.env.APP || 'dev'; 6 | CONFIG.port = process.env.PORT || '3000'; 7 | 8 | CONFIG.db_dialect = process.env.DB_DIALECT || 'mysql'; 9 | CONFIG.db_host = process.env.DB_HOST || 'localhost'; 10 | CONFIG.db_port = process.env.DB_PORT || '3306'; 11 | CONFIG.db_name = process.env.DB_NAME || 'name'; 12 | CONFIG.db_user = process.env.DB_USER || 'root'; 13 | CONFIG.db_password = process.env.DB_PASSWORD || 'db-password'; 14 | 15 | CONFIG.jwt_encryption = process.env.JWT_ENCRYPTION || 'jwt_please_change'; 16 | CONFIG.jwt_expiration = process.env.JWT_EXPIRATION || '10000'; 17 | 18 | module.exports = CONFIG; 19 | -------------------------------------------------------------------------------- /controllers/company.controller.js: -------------------------------------------------------------------------------- 1 | const { Company } = require('../models'); 2 | const { to, ReE, ReS } = require('../services/util.service'); 3 | 4 | const create = async function(req, res){ 5 | let err, company; 6 | let user = req.user; 7 | 8 | let company_info = req.body; 9 | 10 | 11 | [err, company] = await to(Company.create(company_info)); 12 | if(err) return ReE(res, err, 422); 13 | 14 | company.addUser(user, { through: { status: 'started' }}) 15 | 16 | [err, company] = await to(company.save()); 17 | if(err) return ReE(res, err, 422); 18 | 19 | let company_json = company.toWeb(); 20 | company_json.users = [{user:user.id}]; 21 | 22 | return ReS(res, {company:company_json}, 201); 23 | } 24 | module.exports.create = create; 25 | 26 | const getAll = async function(req, res){ 27 | let user = req.user; 28 | let err, companies; 29 | 30 | [err, companies] = await to(user.getCompanies({include: [ {association: Company.Users} ] })); 31 | 32 | let companies_json =[] 33 | for( let i in companies){ 34 | let company = companies[i]; 35 | let users = company.Users; 36 | let company_info = company.toWeb(); 37 | let users_info = []; 38 | for (let i in users){ 39 | let user = users[i]; 40 | // let user_info = user.toJSON(); 41 | users_info.push({user:user.id}); 42 | } 43 | company_info.users = users_info; 44 | companies_json.push(company_info); 45 | } 46 | 47 | console.log('c t', companies_json); 48 | return ReS(res, {companies:companies_json}); 49 | } 50 | module.exports.getAll = getAll; 51 | 52 | const get = function(req, res){ 53 | let company = req.company; 54 | 55 | return ReS(res, {company:company.toWeb()}); 56 | } 57 | module.exports.get = get; 58 | 59 | const update = async function(req, res){ 60 | let err, company, data; 61 | company = req.company; 62 | data = req.body; 63 | company.set(data); 64 | 65 | [err, company] = await to(company.save()); 66 | if(err){ 67 | return ReE(res, err); 68 | } 69 | return ReS(res, {company:company.toWeb()}); 70 | } 71 | module.exports.update = update; 72 | 73 | const remove = async function(req, res){ 74 | let company, err; 75 | company = req.company; 76 | 77 | [err, company] = await to(company.destroy()); 78 | if(err) return ReE(res, 'error occured trying to delete the company'); 79 | 80 | return ReS(res, {message:'Deleted Company'}, 204); 81 | } 82 | module.exports.remove = remove; -------------------------------------------------------------------------------- /controllers/home.controller.js: -------------------------------------------------------------------------------- 1 | const { to, ReE, ReS } = require('../services/util.service'); 2 | 3 | const Dashboard = function(req, res){ 4 | let user = req.user.id; 5 | return res.json({success:true, message:'it worked', data:'user name is :'}); 6 | } 7 | module.exports.Dashboard = Dashboard -------------------------------------------------------------------------------- /controllers/user.controller.js: -------------------------------------------------------------------------------- 1 | const { User } = require('../models'); 2 | const authService = require('../services/auth.service'); 3 | const { to, ReE, ReS } = require('../services/util.service'); 4 | 5 | const create = async function(req, res){ 6 | const body = req.body; 7 | 8 | if(!body.unique_key && !body.email && !body.phone){ 9 | return ReE(res, 'Please enter an email or phone number to register.'); 10 | } else if(!body.password){ 11 | return ReE(res, 'Please enter a password to register.'); 12 | }else{ 13 | let err, user; 14 | 15 | [err, user] = await to(authService.createUser(body)); 16 | 17 | if(err) return ReE(res, err, 422); 18 | return ReS(res, {message:'Successfully created new user.', user:user.toWeb(), token:user.getJWT()}, 201); 19 | } 20 | } 21 | module.exports.create = create; 22 | 23 | const get = async function(req, res){ 24 | let user = req.user; 25 | 26 | return ReS(res, {user:user.toWeb()}); 27 | } 28 | module.exports.get = get; 29 | 30 | const update = async function(req, res){ 31 | let err, user, data 32 | user = req.user; 33 | data = req.body; 34 | user.set(data); 35 | 36 | [err, user] = await to(user.save()); 37 | if(err){ 38 | if(err.message=='Validation error') err = 'The email address or phone number is already in use'; 39 | return ReE(res, err); 40 | } 41 | return ReS(res, {message :'Updated User: '+user.email}); 42 | } 43 | module.exports.update = update; 44 | 45 | const remove = async function(req, res){ 46 | let user, err; 47 | user = req.user; 48 | 49 | [err, user] = await to(user.destroy()); 50 | if(err) return ReE(res, 'error occured trying to delete user'); 51 | 52 | return ReS(res, {message:'Deleted User'}, 204); 53 | } 54 | module.exports.remove = remove; 55 | 56 | 57 | const login = async function(req, res){ 58 | const body = req.body; 59 | let err, user; 60 | 61 | [err, user] = await to(authService.authUser(req.body)); 62 | if(err) return ReE(res, err, 422); 63 | 64 | return ReS(res, {token:user.getJWT(), user:user.toWeb()}); 65 | } 66 | module.exports.login = login; -------------------------------------------------------------------------------- /example.env: -------------------------------------------------------------------------------- 1 | APP=dev 2 | PORT=3000 3 | 4 | DB_DIALECT=mysql 5 | DB_HOST=localhost 6 | DB_PORT=3306 7 | DB_NAME=dbNameChange 8 | DB_USER=rootChange 9 | DB_PASSWORD=passwordChange 10 | 11 | JWT_ENCRYPTION=PleaseChange 12 | JWT_EXPIRATION=10000 -------------------------------------------------------------------------------- /middleware/custom.js: -------------------------------------------------------------------------------- 1 | const Company = require('./../models').Company; 2 | const { to, ReE, ReS } = require('../services/util.service'); 3 | 4 | let company = async function (req, res, next) { 5 | let company_id, err, company; 6 | company_id = req.params.company_id; 7 | 8 | [err, company] = await to(Company.findOne({where:{id:company_id}})); 9 | if(err) return ReE(res, "err finding company"); 10 | 11 | if(!company) return ReE(res, "Company not found with id: "+company_id); 12 | let user, users_array, users; 13 | user = req.user; 14 | [err, users] = await to(company.getUsers()); 15 | 16 | users_array = users.map(obj=>String(obj.user)); 17 | 18 | if(!users_array.includes(String(user._id))) return ReE(res, "User does not have permission to read app with id: "+app_id); 19 | 20 | req.company = company; 21 | next(); 22 | } 23 | module.exports.company = company; -------------------------------------------------------------------------------- /middleware/passport.js: -------------------------------------------------------------------------------- 1 | const { ExtractJwt, Strategy } = require('passport-jwt'); 2 | const { User } = require('../models'); 3 | const CONFIG = require('../config/config'); 4 | const {to} = require('../services/util.service'); 5 | 6 | module.exports = function(passport){ 7 | var opts = {}; 8 | opts.jwtFromRequest = ExtractJwt.fromAuthHeaderAsBearerToken(); 9 | opts.secretOrKey = CONFIG.jwt_encryption; 10 | 11 | passport.use(new Strategy(opts, async function(jwt_payload, done){ 12 | let err, user; 13 | [err, user] = await to(User.findById(jwt_payload.user_id)); 14 | 15 | if(err) return done(err, false); 16 | if(user) { 17 | return done(null, user); 18 | }else{ 19 | return done(null, false); 20 | } 21 | })); 22 | } -------------------------------------------------------------------------------- /migrations/20180116184151-create-user.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | module.exports = { 3 | up: (queryInterface, Sequelize) => { 4 | return queryInterface.createTable('Users', { 5 | id: { 6 | allowNull: false, 7 | autoIncrement: true, 8 | primaryKey: true, 9 | type: Sequelize.INTEGER 10 | }, 11 | first: { 12 | type: Sequelize.STRING 13 | }, 14 | last: { 15 | type: Sequelize.STRING 16 | }, 17 | email: { 18 | type: Sequelize.STRING, 19 | allowNull: false, 20 | unique: true 21 | }, 22 | phone: { 23 | type: Sequelize.STRING, 24 | unique : true, 25 | }, 26 | createdAt: { 27 | allowNull: false, 28 | type: Sequelize.DATE 29 | }, 30 | updatedAt: { 31 | allowNull: false, 32 | type: Sequelize.DATE 33 | } 34 | }); 35 | }, 36 | down: (queryInterface, Sequelize) => { 37 | return queryInterface.dropTable('Users'); 38 | } 39 | }; -------------------------------------------------------------------------------- /migrations/20180118191116-create-company.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | module.exports = { 3 | up: (queryInterface, Sequelize) => { 4 | return queryInterface.createTable('Companies', { 5 | id: { 6 | allowNull: false, 7 | autoIncrement: true, 8 | primaryKey: true, 9 | type: Sequelize.INTEGER 10 | }, 11 | name: { 12 | type: Sequelize.STRING 13 | }, 14 | createdAt: { 15 | allowNull: false, 16 | type: Sequelize.DATE 17 | }, 18 | updatedAt: { 19 | allowNull: false, 20 | type: Sequelize.DATE 21 | } 22 | }); 23 | }, 24 | down: (queryInterface, Sequelize) => { 25 | return queryInterface.dropTable('Companies'); 26 | } 27 | }; -------------------------------------------------------------------------------- /migrations/20180118191640-create-kiosk-group.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | module.exports = { 3 | up: (queryInterface, Sequelize) => { 4 | return queryInterface.createTable('KioskGroups', { 5 | id: { 6 | allowNull: false, 7 | autoIncrement: true, 8 | primaryKey: true, 9 | type: Sequelize.INTEGER 10 | }, 11 | name: { 12 | type: Sequelize.STRING 13 | }, 14 | createdAt: { 15 | allowNull: false, 16 | type: Sequelize.DATE 17 | }, 18 | updatedAt: { 19 | allowNull: false, 20 | type: Sequelize.DATE 21 | } 22 | }); 23 | }, 24 | down: (queryInterface, Sequelize) => { 25 | return queryInterface.dropTable('KioskGroups'); 26 | } 27 | }; -------------------------------------------------------------------------------- /migrations/20180118191702-create-kiosk.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | module.exports = { 3 | up: (queryInterface, Sequelize) => { 4 | return queryInterface.createTable('Kiosks', { 5 | id: { 6 | allowNull: false, 7 | autoIncrement: true, 8 | primaryKey: true, 9 | type: Sequelize.INTEGER 10 | }, 11 | name: { 12 | type: Sequelize.STRING 13 | }, 14 | createdAt: { 15 | allowNull: false, 16 | type: Sequelize.DATE 17 | }, 18 | updatedAt: { 19 | allowNull: false, 20 | type: Sequelize.DATE 21 | } 22 | }); 23 | }, 24 | down: (queryInterface, Sequelize) => { 25 | return queryInterface.dropTable('Kiosks'); 26 | } 27 | }; -------------------------------------------------------------------------------- /migrations/20180118191729-create-catalog.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | module.exports = { 3 | up: (queryInterface, Sequelize) => { 4 | return queryInterface.createTable('Catalogs', { 5 | id: { 6 | allowNull: false, 7 | autoIncrement: true, 8 | primaryKey: true, 9 | type: Sequelize.INTEGER 10 | }, 11 | name: { 12 | type: Sequelize.STRING 13 | }, 14 | createdAt: { 15 | allowNull: false, 16 | type: Sequelize.DATE 17 | }, 18 | updatedAt: { 19 | allowNull: false, 20 | type: Sequelize.DATE 21 | } 22 | }); 23 | }, 24 | down: (queryInterface, Sequelize) => { 25 | return queryInterface.dropTable('Catalogs'); 26 | } 27 | }; -------------------------------------------------------------------------------- /migrations/20180118191738-create-category.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | module.exports = { 3 | up: (queryInterface, Sequelize) => { 4 | return queryInterface.createTable('Categories', { 5 | id: { 6 | allowNull: false, 7 | autoIncrement: true, 8 | primaryKey: true, 9 | type: Sequelize.INTEGER 10 | }, 11 | name: { 12 | type: Sequelize.STRING 13 | }, 14 | createdAt: { 15 | allowNull: false, 16 | type: Sequelize.DATE 17 | }, 18 | updatedAt: { 19 | allowNull: false, 20 | type: Sequelize.DATE 21 | } 22 | }); 23 | }, 24 | down: (queryInterface, Sequelize) => { 25 | return queryInterface.dropTable('Categories'); 26 | } 27 | }; -------------------------------------------------------------------------------- /migrations/20180118191804-create-product.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | module.exports = { 3 | up: (queryInterface, Sequelize) => { 4 | return queryInterface.createTable('Products', { 5 | id: { 6 | allowNull: false, 7 | autoIncrement: true, 8 | primaryKey: true, 9 | type: Sequelize.INTEGER 10 | }, 11 | name: { 12 | type: Sequelize.STRING 13 | }, 14 | createdAt: { 15 | allowNull: false, 16 | type: Sequelize.DATE 17 | }, 18 | updatedAt: { 19 | allowNull: false, 20 | type: Sequelize.DATE 21 | } 22 | }); 23 | }, 24 | down: (queryInterface, Sequelize) => { 25 | return queryInterface.dropTable('Products'); 26 | } 27 | }; -------------------------------------------------------------------------------- /models/company.model.js: -------------------------------------------------------------------------------- 1 | const {TE, to} = require('../services/util.service'); 2 | 3 | module.exports = (sequelize, DataTypes) => { 4 | var Model = sequelize.define('Company', { 5 | name: DataTypes.STRING 6 | }); 7 | 8 | Model.associate = function(models){ 9 | this.Users = this.belongsToMany(models.User, {through: 'UserCompany'}); 10 | }; 11 | 12 | Model.prototype.toWeb = function (pw) { 13 | let json = this.toJSON(); 14 | return json; 15 | }; 16 | 17 | return Model; 18 | }; -------------------------------------------------------------------------------- /models/index.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const fs = require('fs'); 3 | const path = require('path'); 4 | const Sequelize = require('sequelize'); 5 | const basename = path.basename(__filename); 6 | const db = {}; 7 | const CONFIG = require('../config/config'); 8 | 9 | const sequelize = new Sequelize(CONFIG.db_name, CONFIG.db_user, CONFIG.db_password, { 10 | host: CONFIG.db_host, 11 | dialect: CONFIG.db_dialect, 12 | port: CONFIG.db_port, 13 | operatorsAliases: false 14 | }); 15 | 16 | fs.readdirSync(__dirname) 17 | .filter((file) => { 18 | return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js'); 19 | }) 20 | .forEach((file) => { 21 | let model = sequelize['import'](path.join(__dirname, file)); 22 | db[model.name] = model; 23 | }); 24 | 25 | Object.keys(db).forEach((modelName) => { 26 | if (db[modelName].associate) { 27 | db[modelName].associate(db); 28 | } 29 | }); 30 | 31 | db.sequelize = sequelize; 32 | db.Sequelize = Sequelize; 33 | 34 | module.exports = db; 35 | -------------------------------------------------------------------------------- /models/user.model.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const bcrypt = require('bcrypt'); 3 | const bcrypt_p = require('bcrypt-promise'); 4 | const jwt = require('jsonwebtoken'); 5 | const {TE, to} = require('../services/util.service'); 6 | const CONFIG = require('../config/config'); 7 | 8 | module.exports = (sequelize, DataTypes) => { 9 | var Model = sequelize.define('User', { 10 | first : DataTypes.STRING, 11 | last : DataTypes.STRING, 12 | email : {type: DataTypes.STRING, allowNull: true, unique: true, validate: { isEmail: {msg: "Phone number invalid."} }}, 13 | phone : {type: DataTypes.STRING, allowNull: true, unique: true, validate: { len: {args: [7, 20], msg: "Phone number invalid, too short."}, isNumeric: { msg: "not a valid phone number."} }}, 14 | password : DataTypes.STRING, 15 | }); 16 | 17 | Model.associate = function(models){ 18 | this.Companies = this.belongsToMany(models.Company, {through: 'UserCompany'}); 19 | }; 20 | 21 | Model.beforeSave(async (user, options) => { 22 | let err; 23 | if (user.changed('password')){ 24 | let salt, hash 25 | [err, salt] = await to(bcrypt.genSalt(10)); 26 | if(err) TE(err.message, true); 27 | 28 | [err, hash] = await to(bcrypt.hash(user.password, salt)); 29 | if(err) TE(err.message, true); 30 | 31 | user.password = hash; 32 | } 33 | }); 34 | 35 | Model.prototype.comparePassword = async function (pw) { 36 | let err, pass 37 | if(!this.password) TE('password not set'); 38 | 39 | [err, pass] = await to(bcrypt_p.compare(pw, this.password)); 40 | if(err) TE(err); 41 | 42 | if(!pass) TE('invalid password'); 43 | 44 | return this; 45 | } 46 | 47 | Model.prototype.getJWT = function () { 48 | let expiration_time = parseInt(CONFIG.jwt_expiration); 49 | return "Bearer "+jwt.sign({user_id:this.id}, CONFIG.jwt_encryption, {expiresIn: expiration_time}); 50 | }; 51 | 52 | Model.prototype.toWeb = function (pw) { 53 | let json = this.toJSON(); 54 | return json; 55 | }; 56 | 57 | return Model; 58 | }; 59 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "0.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/geojson": { 8 | "version": "1.0.6", 9 | "resolved": "https://registry.npmjs.org/@types/geojson/-/geojson-1.0.6.tgz", 10 | "integrity": "sha512-Xqg/lIZMrUd0VRmSRbCAewtwGZiAk3mEUDvV4op1tGl+LvyPcb/MIOSxTl9z+9+J+R4/vpjiCAT4xeKzH9ji1w==" 11 | }, 12 | "@types/node": { 13 | "version": "9.3.0", 14 | "resolved": "https://registry.npmjs.org/@types/node/-/node-9.3.0.tgz", 15 | "integrity": "sha512-wNBfvNjzsJl4tswIZKXCFQY0lss9nKUyJnG6T94X/eqjRgI2jHZ4evdjhQYBSan/vGtF6XVXPApOmNH2rf0KKw==" 16 | }, 17 | "abbrev": { 18 | "version": "1.1.1", 19 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 20 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 21 | }, 22 | "accepts": { 23 | "version": "1.3.4", 24 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.4.tgz", 25 | "integrity": "sha1-hiRnWMfdbSGmR0/whKR0DsBesh8=", 26 | "requires": { 27 | "mime-types": "2.1.17", 28 | "negotiator": "0.6.1" 29 | } 30 | }, 31 | "acorn": { 32 | "version": "2.7.0", 33 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-2.7.0.tgz", 34 | "integrity": "sha1-q259nYhqrKiwhbwzEreaGYQz8Oc=" 35 | }, 36 | "acorn-globals": { 37 | "version": "1.0.9", 38 | "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-1.0.9.tgz", 39 | "integrity": "sha1-VbtemGkVB7dFedBRNBMhfDgMVM8=", 40 | "requires": { 41 | "acorn": "2.7.0" 42 | } 43 | }, 44 | "ajv": { 45 | "version": "5.2.4", 46 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.2.4.tgz", 47 | "integrity": "sha1-Pa+ai2ciEpn9ro2C0RftjmyAJEs=", 48 | "requires": { 49 | "co": "4.6.0", 50 | "fast-deep-equal": "1.0.0", 51 | "json-schema-traverse": "0.3.1", 52 | "json-stable-stringify": "1.0.1" 53 | } 54 | }, 55 | "align-text": { 56 | "version": "0.1.4", 57 | "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", 58 | "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", 59 | "requires": { 60 | "kind-of": "3.2.2", 61 | "longest": "1.0.1", 62 | "repeat-string": "1.6.1" 63 | } 64 | }, 65 | "amdefine": { 66 | "version": "1.0.1", 67 | "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", 68 | "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=" 69 | }, 70 | "ansi-regex": { 71 | "version": "2.1.1", 72 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 73 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 74 | }, 75 | "ansicolors": { 76 | "version": "0.2.1", 77 | "resolved": "https://registry.npmjs.org/ansicolors/-/ansicolors-0.2.1.tgz", 78 | "integrity": "sha1-vgiVmQl7dKXJxKhKDNvNtivYeu8=" 79 | }, 80 | "aproba": { 81 | "version": "1.2.0", 82 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 83 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 84 | }, 85 | "are-we-there-yet": { 86 | "version": "1.1.4", 87 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz", 88 | "integrity": "sha1-u13KOCu5TwXhUZQ3PRb9O6HKEQ0=", 89 | "requires": { 90 | "delegates": "1.0.0", 91 | "readable-stream": "2.2.7" 92 | } 93 | }, 94 | "array-flatten": { 95 | "version": "1.1.1", 96 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 97 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 98 | }, 99 | "asap": { 100 | "version": "1.0.0", 101 | "resolved": "https://registry.npmjs.org/asap/-/asap-1.0.0.tgz", 102 | "integrity": "sha1-sqRdpf36ILBJb8N2jMJ8EvqRan0=" 103 | }, 104 | "asn1": { 105 | "version": "0.2.3", 106 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", 107 | "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=" 108 | }, 109 | "assert-plus": { 110 | "version": "1.0.0", 111 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 112 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 113 | }, 114 | "asynckit": { 115 | "version": "0.4.0", 116 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 117 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 118 | }, 119 | "await-to-js": { 120 | "version": "2.0.1", 121 | "resolved": "https://registry.npmjs.org/await-to-js/-/await-to-js-2.0.1.tgz", 122 | "integrity": "sha512-zJIZ/G2/sghdDWRMFO2R1Qn4RBPl/OEIe2Cfiz/VXfQS0lmyZwrq4Wmxai4KpvtnsijIadzttwjaSfg1s3CcLQ==" 123 | }, 124 | "aws-sign2": { 125 | "version": "0.7.0", 126 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 127 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 128 | }, 129 | "aws4": { 130 | "version": "1.6.0", 131 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", 132 | "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=" 133 | }, 134 | "babel-runtime": { 135 | "version": "6.26.0", 136 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", 137 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", 138 | "requires": { 139 | "core-js": "2.5.1", 140 | "regenerator-runtime": "0.11.0" 141 | } 142 | }, 143 | "balanced-match": { 144 | "version": "1.0.0", 145 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 146 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 147 | }, 148 | "base64url": { 149 | "version": "2.0.0", 150 | "resolved": "https://registry.npmjs.org/base64url/-/base64url-2.0.0.tgz", 151 | "integrity": "sha1-6sFuA+oUOO/5Qj1puqNiYu0fcLs=" 152 | }, 153 | "basic-auth": { 154 | "version": "2.0.0", 155 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.0.tgz", 156 | "integrity": "sha1-AV2z81PgLlY3d1X5YnQuiYHnu7o=", 157 | "requires": { 158 | "safe-buffer": "5.1.1" 159 | } 160 | }, 161 | "bcrypt": { 162 | "version": "1.0.3", 163 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-1.0.3.tgz", 164 | "integrity": "sha512-pRyDdo73C8Nim3jwFJ7DWe3TZCgwDfWZ6nHS5LSdU77kWbj1frruvdndP02AOavtD4y8v6Fp2dolbHgp4SDrfg==", 165 | "requires": { 166 | "nan": "2.6.2", 167 | "node-pre-gyp": "0.6.36" 168 | } 169 | }, 170 | "bcrypt-pbkdf": { 171 | "version": "1.0.1", 172 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", 173 | "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", 174 | "optional": true, 175 | "requires": { 176 | "tweetnacl": "0.14.5" 177 | } 178 | }, 179 | "bcrypt-promise": { 180 | "version": "2.0.0", 181 | "resolved": "https://registry.npmjs.org/bcrypt-promise/-/bcrypt-promise-2.0.0.tgz", 182 | "integrity": "sha1-oLaD6UNCEArubuaXF0Oj4Xna4nw=" 183 | }, 184 | "block-stream": { 185 | "version": "0.0.9", 186 | "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", 187 | "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", 188 | "requires": { 189 | "inherits": "2.0.3" 190 | } 191 | }, 192 | "bluebird": { 193 | "version": "3.5.1", 194 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 195 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 196 | }, 197 | "body-parser": { 198 | "version": "1.18.2", 199 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.2.tgz", 200 | "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=", 201 | "requires": { 202 | "bytes": "3.0.0", 203 | "content-type": "1.0.4", 204 | "debug": "2.6.9", 205 | "depd": "1.1.1", 206 | "http-errors": "1.6.2", 207 | "iconv-lite": "0.4.19", 208 | "on-finished": "2.3.0", 209 | "qs": "6.5.1", 210 | "raw-body": "2.3.2", 211 | "type-is": "1.6.15" 212 | } 213 | }, 214 | "boom": { 215 | "version": "4.3.1", 216 | "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", 217 | "integrity": "sha1-T4owBctKfjiJ90kDD9JbluAdLjE=", 218 | "requires": { 219 | "hoek": "4.2.0" 220 | } 221 | }, 222 | "brace-expansion": { 223 | "version": "1.1.8", 224 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 225 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 226 | "requires": { 227 | "balanced-match": "1.0.0", 228 | "concat-map": "0.0.1" 229 | } 230 | }, 231 | "buffer-equal-constant-time": { 232 | "version": "1.0.1", 233 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 234 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 235 | }, 236 | "buffer-shims": { 237 | "version": "1.0.0", 238 | "resolved": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz", 239 | "integrity": "sha1-mXjOMXOIxkmth5MCjDR37wRKi1E=" 240 | }, 241 | "builtin-modules": { 242 | "version": "1.1.1", 243 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 244 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=" 245 | }, 246 | "bytes": { 247 | "version": "3.0.0", 248 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 249 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 250 | }, 251 | "camelcase": { 252 | "version": "1.2.1", 253 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", 254 | "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=" 255 | }, 256 | "cardinal": { 257 | "version": "1.0.0", 258 | "resolved": "https://registry.npmjs.org/cardinal/-/cardinal-1.0.0.tgz", 259 | "integrity": "sha1-UOIcGwqjdyn5N33vGWtanOyTLuk=", 260 | "requires": { 261 | "ansicolors": "0.2.1", 262 | "redeyed": "1.0.1" 263 | } 264 | }, 265 | "caseless": { 266 | "version": "0.12.0", 267 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 268 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 269 | }, 270 | "center-align": { 271 | "version": "0.1.3", 272 | "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", 273 | "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", 274 | "requires": { 275 | "align-text": "0.1.4", 276 | "lazy-cache": "1.0.4" 277 | } 278 | }, 279 | "character-parser": { 280 | "version": "1.2.1", 281 | "resolved": "https://registry.npmjs.org/character-parser/-/character-parser-1.2.1.tgz", 282 | "integrity": "sha1-wN3kqxgnE7kZuXCVmhI+zBow/NY=" 283 | }, 284 | "clean-css": { 285 | "version": "3.4.28", 286 | "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-3.4.28.tgz", 287 | "integrity": "sha1-vxlF6C/ICPVWlebd6uwBQA79A/8=", 288 | "requires": { 289 | "commander": "2.8.1", 290 | "source-map": "0.4.4" 291 | }, 292 | "dependencies": { 293 | "commander": { 294 | "version": "2.8.1", 295 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.8.1.tgz", 296 | "integrity": "sha1-Br42f+v9oMMwqh4qBy09yXYkJdQ=", 297 | "requires": { 298 | "graceful-readlink": "1.0.1" 299 | } 300 | } 301 | } 302 | }, 303 | "cli-color": { 304 | "version": "1.2.0", 305 | "resolved": "https://registry.npmjs.org/cli-color/-/cli-color-1.2.0.tgz", 306 | "integrity": "sha1-OlrnT9drYmevZm5p4q+70B3vNNE=", 307 | "requires": { 308 | "ansi-regex": "2.1.1", 309 | "d": "1.0.0", 310 | "es5-ext": "0.10.35", 311 | "es6-iterator": "2.0.3", 312 | "memoizee": "0.4.11", 313 | "timers-ext": "0.1.2" 314 | } 315 | }, 316 | "cliui": { 317 | "version": "2.1.0", 318 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", 319 | "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", 320 | "requires": { 321 | "center-align": "0.1.3", 322 | "right-align": "0.1.3", 323 | "wordwrap": "0.0.2" 324 | }, 325 | "dependencies": { 326 | "wordwrap": { 327 | "version": "0.0.2", 328 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", 329 | "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=" 330 | } 331 | } 332 | }, 333 | "cls-bluebird": { 334 | "version": "2.1.0", 335 | "resolved": "https://registry.npmjs.org/cls-bluebird/-/cls-bluebird-2.1.0.tgz", 336 | "integrity": "sha1-N+8eCAqP+1XC9BZPU28ZGeeWiu4=", 337 | "requires": { 338 | "is-bluebird": "1.0.2", 339 | "shimmer": "1.2.0" 340 | } 341 | }, 342 | "co": { 343 | "version": "4.6.0", 344 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 345 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" 346 | }, 347 | "code-point-at": { 348 | "version": "1.1.0", 349 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 350 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 351 | }, 352 | "combined-stream": { 353 | "version": "1.0.5", 354 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 355 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 356 | "requires": { 357 | "delayed-stream": "1.0.0" 358 | } 359 | }, 360 | "commander": { 361 | "version": "2.6.0", 362 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.6.0.tgz", 363 | "integrity": "sha1-nfflL7Kgyw+4kFjugMMQQiXzfh0=" 364 | }, 365 | "concat-map": { 366 | "version": "0.0.1", 367 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 368 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 369 | }, 370 | "config-chain": { 371 | "version": "1.1.11", 372 | "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.11.tgz", 373 | "integrity": "sha1-q6CXR9++TD5w52am5BWG4YWfxvI=", 374 | "requires": { 375 | "ini": "1.3.4", 376 | "proto-list": "1.2.4" 377 | } 378 | }, 379 | "console-control-strings": { 380 | "version": "1.1.0", 381 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 382 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 383 | }, 384 | "constantinople": { 385 | "version": "3.0.2", 386 | "resolved": "https://registry.npmjs.org/constantinople/-/constantinople-3.0.2.tgz", 387 | "integrity": "sha1-S5RdmTeQe82Y7ldRIsOBdRZUQUE=", 388 | "requires": { 389 | "acorn": "2.7.0" 390 | } 391 | }, 392 | "content-disposition": { 393 | "version": "0.5.2", 394 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 395 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 396 | }, 397 | "content-type": { 398 | "version": "1.0.4", 399 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 400 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 401 | }, 402 | "cookie": { 403 | "version": "0.3.1", 404 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 405 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 406 | }, 407 | "cookie-parser": { 408 | "version": "1.4.3", 409 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.3.tgz", 410 | "integrity": "sha1-D+MfoZ0AC5X0qt8fU/3CuKIDuqU=", 411 | "requires": { 412 | "cookie": "0.3.1", 413 | "cookie-signature": "1.0.6" 414 | } 415 | }, 416 | "cookie-signature": { 417 | "version": "1.0.6", 418 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 419 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 420 | }, 421 | "core-js": { 422 | "version": "2.5.1", 423 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.1.tgz", 424 | "integrity": "sha1-rmh03GaTd4m4B1T/VCjfZoGcpQs=" 425 | }, 426 | "core-util-is": { 427 | "version": "1.0.2", 428 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 429 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 430 | }, 431 | "cors": { 432 | "version": "2.8.4", 433 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.4.tgz", 434 | "integrity": "sha1-K9OB8usgECAQXNUOpZ2mMJBpRoY=", 435 | "requires": { 436 | "object-assign": "4.1.1", 437 | "vary": "1.1.2" 438 | } 439 | }, 440 | "cross-spawn": { 441 | "version": "5.1.0", 442 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 443 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 444 | "requires": { 445 | "lru-cache": "4.1.1", 446 | "shebang-command": "1.2.0", 447 | "which": "1.3.0" 448 | } 449 | }, 450 | "cryptiles": { 451 | "version": "3.1.2", 452 | "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-3.1.2.tgz", 453 | "integrity": "sha1-qJ+7Ig9c4l7FboxKqKT9e1sNKf4=", 454 | "requires": { 455 | "boom": "5.2.0" 456 | }, 457 | "dependencies": { 458 | "boom": { 459 | "version": "5.2.0", 460 | "resolved": "https://registry.npmjs.org/boom/-/boom-5.2.0.tgz", 461 | "integrity": "sha512-Z5BTk6ZRe4tXXQlkqftmsAUANpXmuwlsF5Oov8ThoMbQRzdGTA1ngYRW160GexgOgjsFOKJz0LYhoNi+2AMBUw==", 462 | "requires": { 463 | "hoek": "4.2.0" 464 | } 465 | } 466 | } 467 | }, 468 | "css": { 469 | "version": "1.0.8", 470 | "resolved": "https://registry.npmjs.org/css/-/css-1.0.8.tgz", 471 | "integrity": "sha1-k4aBHKgrzMnuf7WnMrHioxfIo+c=", 472 | "requires": { 473 | "css-parse": "1.0.4", 474 | "css-stringify": "1.0.5" 475 | } 476 | }, 477 | "css-parse": { 478 | "version": "1.0.4", 479 | "resolved": "https://registry.npmjs.org/css-parse/-/css-parse-1.0.4.tgz", 480 | "integrity": "sha1-OLBQP7+dqfVOnB29pg4UXHcRe90=" 481 | }, 482 | "css-stringify": { 483 | "version": "1.0.5", 484 | "resolved": "https://registry.npmjs.org/css-stringify/-/css-stringify-1.0.5.tgz", 485 | "integrity": "sha1-sNBClG2ylTu50pKQCmy19tASIDE=" 486 | }, 487 | "d": { 488 | "version": "1.0.0", 489 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.0.tgz", 490 | "integrity": "sha1-dUu1v+VUUdpppYuU1F9MWwRi1Y8=", 491 | "requires": { 492 | "es5-ext": "0.10.35" 493 | } 494 | }, 495 | "dashdash": { 496 | "version": "1.14.1", 497 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 498 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 499 | "requires": { 500 | "assert-plus": "1.0.0" 501 | } 502 | }, 503 | "debug": { 504 | "version": "2.6.9", 505 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 506 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 507 | "requires": { 508 | "ms": "2.0.0" 509 | } 510 | }, 511 | "decamelize": { 512 | "version": "1.2.0", 513 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 514 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 515 | }, 516 | "deep-extend": { 517 | "version": "0.4.2", 518 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.4.2.tgz", 519 | "integrity": "sha1-SLaZwn4zS/ifEIkr5DL25MfTSn8=" 520 | }, 521 | "delayed-stream": { 522 | "version": "1.0.0", 523 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 524 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 525 | }, 526 | "delegates": { 527 | "version": "1.0.0", 528 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 529 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 530 | }, 531 | "denque": { 532 | "version": "1.2.2", 533 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.2.2.tgz", 534 | "integrity": "sha512-x92Ql74lcTbGylXILO9Xf9S0cMpEPP04zVp2bB9e2C7G/n/Q1SgLl78RaSYEPSgpDX9uLgQXCEGAS5BI5dP3yA==" 535 | }, 536 | "depd": { 537 | "version": "1.1.1", 538 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz", 539 | "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=" 540 | }, 541 | "destroy": { 542 | "version": "1.0.4", 543 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 544 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 545 | }, 546 | "dotenv": { 547 | "version": "4.0.0", 548 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-4.0.0.tgz", 549 | "integrity": "sha1-hk7xN5rO1Vzm+V3r7NzhefegzR0=" 550 | }, 551 | "dottie": { 552 | "version": "2.0.0", 553 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.0.tgz", 554 | "integrity": "sha1-2hkZgci41xPKARXViYzzl8Lw3dA=" 555 | }, 556 | "ecc-jsbn": { 557 | "version": "0.1.1", 558 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", 559 | "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", 560 | "optional": true, 561 | "requires": { 562 | "jsbn": "0.1.1" 563 | } 564 | }, 565 | "ecdsa-sig-formatter": { 566 | "version": "1.0.9", 567 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.9.tgz", 568 | "integrity": "sha1-S8kmJ07Dtau1AW5+HWCSGsJisqE=", 569 | "requires": { 570 | "base64url": "2.0.0", 571 | "safe-buffer": "5.1.1" 572 | } 573 | }, 574 | "editorconfig": { 575 | "version": "0.13.3", 576 | "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.13.3.tgz", 577 | "integrity": "sha512-WkjsUNVCu+ITKDj73QDvi0trvpdDWdkDyHybDGSXPfekLCqwmpD7CP7iPbvBgosNuLcI96XTDwNa75JyFl7tEQ==", 578 | "requires": { 579 | "bluebird": "3.5.1", 580 | "commander": "2.11.0", 581 | "lru-cache": "3.2.0", 582 | "semver": "5.4.1", 583 | "sigmund": "1.0.1" 584 | }, 585 | "dependencies": { 586 | "commander": { 587 | "version": "2.11.0", 588 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 589 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==" 590 | }, 591 | "lru-cache": { 592 | "version": "3.2.0", 593 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-3.2.0.tgz", 594 | "integrity": "sha1-cXibO39Tmb7IVl3aOKow0qCX7+4=", 595 | "requires": { 596 | "pseudomap": "1.0.2" 597 | } 598 | } 599 | } 600 | }, 601 | "ee-first": { 602 | "version": "1.1.1", 603 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 604 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 605 | }, 606 | "encodeurl": { 607 | "version": "1.0.1", 608 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", 609 | "integrity": "sha1-eePVhlU0aQn+bw9Fpd5oEDspTSA=" 610 | }, 611 | "error-ex": { 612 | "version": "1.3.1", 613 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", 614 | "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", 615 | "requires": { 616 | "is-arrayish": "0.2.1" 617 | } 618 | }, 619 | "es5-ext": { 620 | "version": "0.10.35", 621 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.35.tgz", 622 | "integrity": "sha1-GO6FjOajxFx9eekcFfzKnsVoSU8=", 623 | "requires": { 624 | "es6-iterator": "2.0.3", 625 | "es6-symbol": "3.1.1" 626 | } 627 | }, 628 | "es6-iterator": { 629 | "version": "2.0.3", 630 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 631 | "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", 632 | "requires": { 633 | "d": "1.0.0", 634 | "es5-ext": "0.10.35", 635 | "es6-symbol": "3.1.1" 636 | } 637 | }, 638 | "es6-symbol": { 639 | "version": "3.1.1", 640 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.1.tgz", 641 | "integrity": "sha1-vwDvT9q2uhtG7Le2KbTH7VcVzHc=", 642 | "requires": { 643 | "d": "1.0.0", 644 | "es5-ext": "0.10.35" 645 | } 646 | }, 647 | "es6-weak-map": { 648 | "version": "2.0.2", 649 | "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.2.tgz", 650 | "integrity": "sha1-XjqzIlH/0VOKH45f+hNXdy+S2W8=", 651 | "requires": { 652 | "d": "1.0.0", 653 | "es5-ext": "0.10.35", 654 | "es6-iterator": "2.0.3", 655 | "es6-symbol": "3.1.1" 656 | } 657 | }, 658 | "escape-html": { 659 | "version": "1.0.3", 660 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 661 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 662 | }, 663 | "esprima": { 664 | "version": "3.0.0", 665 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.0.0.tgz", 666 | "integrity": "sha1-U88kes2ncxPlUcOqLnM0LT+099k=" 667 | }, 668 | "etag": { 669 | "version": "1.8.1", 670 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 671 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 672 | }, 673 | "event-emitter": { 674 | "version": "0.3.5", 675 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 676 | "integrity": "sha1-34xp7vFkeSPHFXuc6DhAYQsCzDk=", 677 | "requires": { 678 | "d": "1.0.0", 679 | "es5-ext": "0.10.35" 680 | } 681 | }, 682 | "execa": { 683 | "version": "0.7.0", 684 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", 685 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", 686 | "requires": { 687 | "cross-spawn": "5.1.0", 688 | "get-stream": "3.0.0", 689 | "is-stream": "1.1.0", 690 | "npm-run-path": "2.0.2", 691 | "p-finally": "1.0.0", 692 | "signal-exit": "3.0.2", 693 | "strip-eof": "1.0.0" 694 | } 695 | }, 696 | "express": { 697 | "version": "4.15.5", 698 | "resolved": "https://registry.npmjs.org/express/-/express-4.15.5.tgz", 699 | "integrity": "sha1-ZwI1ypWYiQpa6BcLg9tyK4Qu2Sc=", 700 | "requires": { 701 | "accepts": "1.3.4", 702 | "array-flatten": "1.1.1", 703 | "content-disposition": "0.5.2", 704 | "content-type": "1.0.4", 705 | "cookie": "0.3.1", 706 | "cookie-signature": "1.0.6", 707 | "debug": "2.6.9", 708 | "depd": "1.1.1", 709 | "encodeurl": "1.0.1", 710 | "escape-html": "1.0.3", 711 | "etag": "1.8.1", 712 | "finalhandler": "1.0.6", 713 | "fresh": "0.5.2", 714 | "merge-descriptors": "1.0.1", 715 | "methods": "1.1.2", 716 | "on-finished": "2.3.0", 717 | "parseurl": "1.3.2", 718 | "path-to-regexp": "0.1.7", 719 | "proxy-addr": "1.1.5", 720 | "qs": "6.5.0", 721 | "range-parser": "1.2.0", 722 | "send": "0.15.6", 723 | "serve-static": "1.12.6", 724 | "setprototypeof": "1.0.3", 725 | "statuses": "1.3.1", 726 | "type-is": "1.6.15", 727 | "utils-merge": "1.0.0", 728 | "vary": "1.1.2" 729 | }, 730 | "dependencies": { 731 | "qs": { 732 | "version": "6.5.0", 733 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.0.tgz", 734 | "integrity": "sha512-fjVFjW9yhqMhVGwRExCXLhJKrLlkYSaxNWdyc9rmHlrVZbk35YHH312dFd7191uQeXkI3mKLZTIbSvIeFwFemg==" 735 | }, 736 | "statuses": { 737 | "version": "1.3.1", 738 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 739 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 740 | } 741 | } 742 | }, 743 | "extend": { 744 | "version": "3.0.1", 745 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 746 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=" 747 | }, 748 | "extsprintf": { 749 | "version": "1.3.0", 750 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 751 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 752 | }, 753 | "fast-deep-equal": { 754 | "version": "1.0.0", 755 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", 756 | "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=" 757 | }, 758 | "finalhandler": { 759 | "version": "1.0.6", 760 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.0.6.tgz", 761 | "integrity": "sha1-AHrqM9Gk0+QgF/YkhIrVjSEvgU8=", 762 | "requires": { 763 | "debug": "2.6.9", 764 | "encodeurl": "1.0.1", 765 | "escape-html": "1.0.3", 766 | "on-finished": "2.3.0", 767 | "parseurl": "1.3.2", 768 | "statuses": "1.3.1", 769 | "unpipe": "1.0.0" 770 | }, 771 | "dependencies": { 772 | "statuses": { 773 | "version": "1.3.1", 774 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 775 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 776 | } 777 | } 778 | }, 779 | "find-up": { 780 | "version": "2.1.0", 781 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 782 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 783 | "requires": { 784 | "locate-path": "2.0.0" 785 | } 786 | }, 787 | "forever-agent": { 788 | "version": "0.6.1", 789 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 790 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 791 | }, 792 | "form-data": { 793 | "version": "2.3.1", 794 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", 795 | "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", 796 | "requires": { 797 | "asynckit": "0.4.0", 798 | "combined-stream": "1.0.5", 799 | "mime-types": "2.1.17" 800 | } 801 | }, 802 | "forwarded": { 803 | "version": "0.1.2", 804 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 805 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 806 | }, 807 | "fresh": { 808 | "version": "0.5.2", 809 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 810 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 811 | }, 812 | "fs-extra": { 813 | "version": "4.0.2", 814 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-4.0.2.tgz", 815 | "integrity": "sha1-+RcExT0bRh+JNFKwwwfZmXZHq2s=", 816 | "requires": { 817 | "graceful-fs": "4.1.11", 818 | "jsonfile": "4.0.0", 819 | "universalify": "0.1.1" 820 | } 821 | }, 822 | "fs.realpath": { 823 | "version": "1.0.0", 824 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 825 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 826 | }, 827 | "fstream": { 828 | "version": "1.0.11", 829 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", 830 | "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", 831 | "requires": { 832 | "graceful-fs": "4.1.11", 833 | "inherits": "2.0.3", 834 | "mkdirp": "0.5.1", 835 | "rimraf": "2.6.2" 836 | } 837 | }, 838 | "fstream-ignore": { 839 | "version": "1.0.5", 840 | "resolved": "https://registry.npmjs.org/fstream-ignore/-/fstream-ignore-1.0.5.tgz", 841 | "integrity": "sha1-nDHa40dnAY/h0kmyTa2mfQktoQU=", 842 | "requires": { 843 | "fstream": "1.0.11", 844 | "inherits": "2.0.3", 845 | "minimatch": "3.0.4" 846 | } 847 | }, 848 | "gauge": { 849 | "version": "2.7.4", 850 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 851 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 852 | "requires": { 853 | "aproba": "1.2.0", 854 | "console-control-strings": "1.1.0", 855 | "has-unicode": "2.0.1", 856 | "object-assign": "4.1.1", 857 | "signal-exit": "3.0.2", 858 | "string-width": "1.0.2", 859 | "strip-ansi": "3.0.1", 860 | "wide-align": "1.1.2" 861 | } 862 | }, 863 | "generate-function": { 864 | "version": "2.0.0", 865 | "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.0.0.tgz", 866 | "integrity": "sha1-aFj+fAlpt9TpCTM3ZHrHn2DfvnQ=" 867 | }, 868 | "generic-pool": { 869 | "version": "3.4.0", 870 | "resolved": "https://registry.npmjs.org/generic-pool/-/generic-pool-3.4.0.tgz", 871 | "integrity": "sha512-lYsIpjkyNBnRLKrcnJlXTEXB2ISmK9g7N4WqWwXbvr+tVB1+raaFnHoCYecWnuCo/XGHgM935WOWmr5Zx3tJKw==" 872 | }, 873 | "get-caller-file": { 874 | "version": "1.0.2", 875 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.2.tgz", 876 | "integrity": "sha1-9wLmMSfn4jHBYKgMFVSstw1QR+U=" 877 | }, 878 | "get-stream": { 879 | "version": "3.0.0", 880 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 881 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=" 882 | }, 883 | "getpass": { 884 | "version": "0.1.7", 885 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 886 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 887 | "requires": { 888 | "assert-plus": "1.0.0" 889 | } 890 | }, 891 | "glob": { 892 | "version": "7.1.2", 893 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 894 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 895 | "requires": { 896 | "fs.realpath": "1.0.0", 897 | "inflight": "1.0.6", 898 | "inherits": "2.0.3", 899 | "minimatch": "3.0.4", 900 | "once": "1.4.0", 901 | "path-is-absolute": "1.0.1" 902 | } 903 | }, 904 | "graceful-fs": { 905 | "version": "4.1.11", 906 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 907 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" 908 | }, 909 | "graceful-readlink": { 910 | "version": "1.0.1", 911 | "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz", 912 | "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=" 913 | }, 914 | "har-schema": { 915 | "version": "2.0.0", 916 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 917 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 918 | }, 919 | "har-validator": { 920 | "version": "5.0.3", 921 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.0.3.tgz", 922 | "integrity": "sha1-ukAsJmGU8VlW7xXg/PJCmT9qff0=", 923 | "requires": { 924 | "ajv": "5.2.4", 925 | "har-schema": "2.0.0" 926 | } 927 | }, 928 | "has-unicode": { 929 | "version": "2.0.1", 930 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 931 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 932 | }, 933 | "hawk": { 934 | "version": "6.0.2", 935 | "resolved": "https://registry.npmjs.org/hawk/-/hawk-6.0.2.tgz", 936 | "integrity": "sha512-miowhl2+U7Qle4vdLqDdPt9m09K6yZhkLDTWGoUiUzrQCn+mHHSmfJgAyGaLRZbPmTqfFFjRV1QWCW0VWUJBbQ==", 937 | "requires": { 938 | "boom": "4.3.1", 939 | "cryptiles": "3.1.2", 940 | "hoek": "4.2.0", 941 | "sntp": "2.0.2" 942 | } 943 | }, 944 | "hoek": { 945 | "version": "4.2.0", 946 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.0.tgz", 947 | "integrity": "sha512-v0XCLxICi9nPfYrS9RL8HbYnXi9obYAeLbSP00BmnZwCK9+Ih9WOjoZ8YoHCoav2csqn4FOz4Orldsy2dmDwmQ==" 948 | }, 949 | "hosted-git-info": { 950 | "version": "2.5.0", 951 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.5.0.tgz", 952 | "integrity": "sha512-pNgbURSuab90KbTqvRPsseaTxOJCZBD0a7t+haSN33piP9cCM4l0CqdzAif2hUqm716UovKB2ROmiabGAKVXyg==" 953 | }, 954 | "http-errors": { 955 | "version": "1.6.2", 956 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz", 957 | "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=", 958 | "requires": { 959 | "depd": "1.1.1", 960 | "inherits": "2.0.3", 961 | "setprototypeof": "1.0.3", 962 | "statuses": "1.4.0" 963 | } 964 | }, 965 | "http-signature": { 966 | "version": "1.2.0", 967 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 968 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 969 | "requires": { 970 | "assert-plus": "1.0.0", 971 | "jsprim": "1.4.1", 972 | "sshpk": "1.13.1" 973 | } 974 | }, 975 | "iconv-lite": { 976 | "version": "0.4.19", 977 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 978 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==" 979 | }, 980 | "inflection": { 981 | "version": "1.12.0", 982 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.12.0.tgz", 983 | "integrity": "sha1-ogCTVlbW9fa8TcdQLhrstwMihBY=" 984 | }, 985 | "inflight": { 986 | "version": "1.0.6", 987 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 988 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 989 | "requires": { 990 | "once": "1.4.0", 991 | "wrappy": "1.0.2" 992 | } 993 | }, 994 | "inherits": { 995 | "version": "2.0.3", 996 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 997 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 998 | }, 999 | "ini": { 1000 | "version": "1.3.4", 1001 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.4.tgz", 1002 | "integrity": "sha1-BTfLedr1m1mhpRff9wbIbsA5Fi4=" 1003 | }, 1004 | "invert-kv": { 1005 | "version": "1.0.0", 1006 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", 1007 | "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=" 1008 | }, 1009 | "ipaddr.js": { 1010 | "version": "1.4.0", 1011 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.4.0.tgz", 1012 | "integrity": "sha1-KWrKh4qCGBbluF0KKFqZvP9FgvA=" 1013 | }, 1014 | "is-arrayish": { 1015 | "version": "0.2.1", 1016 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1017 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" 1018 | }, 1019 | "is-bluebird": { 1020 | "version": "1.0.2", 1021 | "resolved": "https://registry.npmjs.org/is-bluebird/-/is-bluebird-1.0.2.tgz", 1022 | "integrity": "sha1-CWQ5Bg9KpBGr7hkUOoTWpVNG1uI=" 1023 | }, 1024 | "is-buffer": { 1025 | "version": "1.1.5", 1026 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.5.tgz", 1027 | "integrity": "sha1-Hzsm72E7IUuIy8ojzGwB2Hlh7sw=" 1028 | }, 1029 | "is-builtin-module": { 1030 | "version": "1.0.0", 1031 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 1032 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 1033 | "requires": { 1034 | "builtin-modules": "1.1.1" 1035 | } 1036 | }, 1037 | "is-fullwidth-code-point": { 1038 | "version": "1.0.0", 1039 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1040 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1041 | "requires": { 1042 | "number-is-nan": "1.0.1" 1043 | } 1044 | }, 1045 | "is-promise": { 1046 | "version": "2.1.0", 1047 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1048 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 1049 | }, 1050 | "is-stream": { 1051 | "version": "1.1.0", 1052 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1053 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 1054 | }, 1055 | "is-typedarray": { 1056 | "version": "1.0.0", 1057 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1058 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 1059 | }, 1060 | "isarray": { 1061 | "version": "1.0.0", 1062 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1063 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1064 | }, 1065 | "isemail": { 1066 | "version": "1.2.0", 1067 | "resolved": "https://registry.npmjs.org/isemail/-/isemail-1.2.0.tgz", 1068 | "integrity": "sha1-vgPfjMPineTSxd9lASY/H6RZXpo=" 1069 | }, 1070 | "isexe": { 1071 | "version": "2.0.0", 1072 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1073 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 1074 | }, 1075 | "isstream": { 1076 | "version": "0.1.2", 1077 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1078 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 1079 | }, 1080 | "jade": { 1081 | "version": "1.11.0", 1082 | "resolved": "https://registry.npmjs.org/jade/-/jade-1.11.0.tgz", 1083 | "integrity": "sha1-nIDlOMEtP7lcjZu5VZ+gzAQEBf0=", 1084 | "requires": { 1085 | "character-parser": "1.2.1", 1086 | "clean-css": "3.4.28", 1087 | "commander": "2.6.0", 1088 | "constantinople": "3.0.2", 1089 | "jstransformer": "0.0.2", 1090 | "mkdirp": "0.5.1", 1091 | "transformers": "2.1.0", 1092 | "uglify-js": "2.8.29", 1093 | "void-elements": "2.0.1", 1094 | "with": "4.0.3" 1095 | } 1096 | }, 1097 | "joi": { 1098 | "version": "6.10.1", 1099 | "resolved": "https://registry.npmjs.org/joi/-/joi-6.10.1.tgz", 1100 | "integrity": "sha1-TVDDGAeRIgAP5fFq8f+OGRe3fgY=", 1101 | "requires": { 1102 | "hoek": "2.16.3", 1103 | "isemail": "1.2.0", 1104 | "moment": "2.19.1", 1105 | "topo": "1.1.0" 1106 | }, 1107 | "dependencies": { 1108 | "hoek": { 1109 | "version": "2.16.3", 1110 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", 1111 | "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=" 1112 | } 1113 | } 1114 | }, 1115 | "js-beautify": { 1116 | "version": "1.7.4", 1117 | "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.7.4.tgz", 1118 | "integrity": "sha512-6YX1g+lIl0/JDxjFFbgj7fz6i0bWFa2Hdc7PfGqFhynaEiYe1NJ3R1nda0VGaRiGU82OllR+EGDoWFpGr3k5Kg==", 1119 | "requires": { 1120 | "config-chain": "1.1.11", 1121 | "editorconfig": "0.13.3", 1122 | "mkdirp": "0.5.1", 1123 | "nopt": "3.0.6" 1124 | }, 1125 | "dependencies": { 1126 | "nopt": { 1127 | "version": "3.0.6", 1128 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", 1129 | "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", 1130 | "requires": { 1131 | "abbrev": "1.1.1" 1132 | } 1133 | } 1134 | } 1135 | }, 1136 | "jsbn": { 1137 | "version": "0.1.1", 1138 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1139 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1140 | "optional": true 1141 | }, 1142 | "json-schema": { 1143 | "version": "0.2.3", 1144 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1145 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 1146 | }, 1147 | "json-schema-traverse": { 1148 | "version": "0.3.1", 1149 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 1150 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=" 1151 | }, 1152 | "json-stable-stringify": { 1153 | "version": "1.0.1", 1154 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", 1155 | "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", 1156 | "requires": { 1157 | "jsonify": "0.0.0" 1158 | } 1159 | }, 1160 | "json-stringify-safe": { 1161 | "version": "5.0.1", 1162 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1163 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 1164 | }, 1165 | "jsonfile": { 1166 | "version": "4.0.0", 1167 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 1168 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 1169 | "requires": { 1170 | "graceful-fs": "4.1.11" 1171 | } 1172 | }, 1173 | "jsonify": { 1174 | "version": "0.0.0", 1175 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 1176 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=" 1177 | }, 1178 | "jsonwebtoken": { 1179 | "version": "7.4.3", 1180 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-7.4.3.tgz", 1181 | "integrity": "sha1-d/UCHeBYtgWheD+hKD6ZgS5kVjg=", 1182 | "requires": { 1183 | "joi": "6.10.1", 1184 | "jws": "3.1.4", 1185 | "lodash.once": "4.1.1", 1186 | "ms": "2.0.0", 1187 | "xtend": "4.0.1" 1188 | } 1189 | }, 1190 | "jsprim": { 1191 | "version": "1.4.1", 1192 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1193 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1194 | "requires": { 1195 | "assert-plus": "1.0.0", 1196 | "extsprintf": "1.3.0", 1197 | "json-schema": "0.2.3", 1198 | "verror": "1.10.0" 1199 | } 1200 | }, 1201 | "jstransformer": { 1202 | "version": "0.0.2", 1203 | "resolved": "https://registry.npmjs.org/jstransformer/-/jstransformer-0.0.2.tgz", 1204 | "integrity": "sha1-eq4pqQPRls+glz2IXT5HlH7Ndqs=", 1205 | "requires": { 1206 | "is-promise": "2.1.0", 1207 | "promise": "6.1.0" 1208 | } 1209 | }, 1210 | "jwa": { 1211 | "version": "1.1.5", 1212 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.1.5.tgz", 1213 | "integrity": "sha1-oFUs4CIHQs1S4VN3SjKQXDDnVuU=", 1214 | "requires": { 1215 | "base64url": "2.0.0", 1216 | "buffer-equal-constant-time": "1.0.1", 1217 | "ecdsa-sig-formatter": "1.0.9", 1218 | "safe-buffer": "5.1.1" 1219 | } 1220 | }, 1221 | "jws": { 1222 | "version": "3.1.4", 1223 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.1.4.tgz", 1224 | "integrity": "sha1-+ei5M46KhHJ31kRLFGT2GIDgUKI=", 1225 | "requires": { 1226 | "base64url": "2.0.0", 1227 | "jwa": "1.1.5", 1228 | "safe-buffer": "5.1.1" 1229 | } 1230 | }, 1231 | "kind-of": { 1232 | "version": "3.2.2", 1233 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1234 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1235 | "requires": { 1236 | "is-buffer": "1.1.5" 1237 | } 1238 | }, 1239 | "lazy-cache": { 1240 | "version": "1.0.4", 1241 | "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", 1242 | "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=" 1243 | }, 1244 | "lcid": { 1245 | "version": "1.0.0", 1246 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", 1247 | "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", 1248 | "requires": { 1249 | "invert-kv": "1.0.0" 1250 | } 1251 | }, 1252 | "load-json-file": { 1253 | "version": "2.0.0", 1254 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1255 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1256 | "requires": { 1257 | "graceful-fs": "4.1.11", 1258 | "parse-json": "2.2.0", 1259 | "pify": "2.3.0", 1260 | "strip-bom": "3.0.0" 1261 | } 1262 | }, 1263 | "locate-path": { 1264 | "version": "2.0.0", 1265 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1266 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1267 | "requires": { 1268 | "p-locate": "2.0.0", 1269 | "path-exists": "3.0.0" 1270 | } 1271 | }, 1272 | "lodash": { 1273 | "version": "4.17.4", 1274 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 1275 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" 1276 | }, 1277 | "lodash.once": { 1278 | "version": "4.1.1", 1279 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1280 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1281 | }, 1282 | "long": { 1283 | "version": "3.2.0", 1284 | "resolved": "https://registry.npmjs.org/long/-/long-3.2.0.tgz", 1285 | "integrity": "sha1-2CG3E4yhy1gcFymQ7xTbIAtcR0s=" 1286 | }, 1287 | "longest": { 1288 | "version": "1.0.1", 1289 | "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", 1290 | "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=" 1291 | }, 1292 | "lru-cache": { 1293 | "version": "4.1.1", 1294 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", 1295 | "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", 1296 | "requires": { 1297 | "pseudomap": "1.0.2", 1298 | "yallist": "2.1.2" 1299 | } 1300 | }, 1301 | "lru-queue": { 1302 | "version": "0.1.0", 1303 | "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", 1304 | "integrity": "sha1-Jzi9nw089PhEkMVzbEhpmsYyzaM=", 1305 | "requires": { 1306 | "es5-ext": "0.10.35" 1307 | } 1308 | }, 1309 | "media-typer": { 1310 | "version": "0.3.0", 1311 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1312 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1313 | }, 1314 | "mem": { 1315 | "version": "1.1.0", 1316 | "resolved": "https://registry.npmjs.org/mem/-/mem-1.1.0.tgz", 1317 | "integrity": "sha1-Xt1StIXKHZAP5kiVUFOZoN+kX3Y=", 1318 | "requires": { 1319 | "mimic-fn": "1.1.0" 1320 | } 1321 | }, 1322 | "memoizee": { 1323 | "version": "0.4.11", 1324 | "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.11.tgz", 1325 | "integrity": "sha1-vemBdmPJ5A/bKk6hw2cpYIeujI8=", 1326 | "requires": { 1327 | "d": "1.0.0", 1328 | "es5-ext": "0.10.35", 1329 | "es6-weak-map": "2.0.2", 1330 | "event-emitter": "0.3.5", 1331 | "is-promise": "2.1.0", 1332 | "lru-queue": "0.1.0", 1333 | "next-tick": "1.0.0", 1334 | "timers-ext": "0.1.2" 1335 | } 1336 | }, 1337 | "merge-descriptors": { 1338 | "version": "1.0.1", 1339 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1340 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1341 | }, 1342 | "methods": { 1343 | "version": "1.1.2", 1344 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1345 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1346 | }, 1347 | "mime": { 1348 | "version": "1.3.4", 1349 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.3.4.tgz", 1350 | "integrity": "sha1-EV+eO2s9rylZmDyzjxSaLUDrXVM=" 1351 | }, 1352 | "mime-db": { 1353 | "version": "1.30.0", 1354 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", 1355 | "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=" 1356 | }, 1357 | "mime-types": { 1358 | "version": "2.1.17", 1359 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", 1360 | "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", 1361 | "requires": { 1362 | "mime-db": "1.30.0" 1363 | } 1364 | }, 1365 | "mimic-fn": { 1366 | "version": "1.1.0", 1367 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.1.0.tgz", 1368 | "integrity": "sha1-5md4PZLonb00KBi1IwudYqZyrRg=" 1369 | }, 1370 | "minimatch": { 1371 | "version": "3.0.4", 1372 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1373 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1374 | "requires": { 1375 | "brace-expansion": "1.1.8" 1376 | } 1377 | }, 1378 | "minimist": { 1379 | "version": "0.0.8", 1380 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1381 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 1382 | }, 1383 | "mkdirp": { 1384 | "version": "0.5.1", 1385 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1386 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1387 | "requires": { 1388 | "minimist": "0.0.8" 1389 | } 1390 | }, 1391 | "moment": { 1392 | "version": "2.19.1", 1393 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.19.1.tgz", 1394 | "integrity": "sha1-VtoaLRy/AdOLfhr8McELz6GSkWc=" 1395 | }, 1396 | "moment-timezone": { 1397 | "version": "0.5.14", 1398 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.14.tgz", 1399 | "integrity": "sha1-TrOP+VOLgBCLpGekWPPtQmjM/LE=", 1400 | "requires": { 1401 | "moment": "2.19.1" 1402 | } 1403 | }, 1404 | "morgan": { 1405 | "version": "1.9.0", 1406 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.9.0.tgz", 1407 | "integrity": "sha1-0B+mxlhZt2/PMbPLU6OCGjEdgFE=", 1408 | "requires": { 1409 | "basic-auth": "2.0.0", 1410 | "debug": "2.6.9", 1411 | "depd": "1.1.1", 1412 | "on-finished": "2.3.0", 1413 | "on-headers": "1.0.1" 1414 | } 1415 | }, 1416 | "ms": { 1417 | "version": "2.0.0", 1418 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1419 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1420 | }, 1421 | "mysql2": { 1422 | "version": "1.5.1", 1423 | "resolved": "https://registry.npmjs.org/mysql2/-/mysql2-1.5.1.tgz", 1424 | "integrity": "sha1-JBHW+5WK+GsjBLelO8VLJud+aCs=", 1425 | "requires": { 1426 | "cardinal": "1.0.0", 1427 | "denque": "1.2.2", 1428 | "generate-function": "2.0.0", 1429 | "iconv-lite": "0.4.19", 1430 | "long": "3.2.0", 1431 | "lru-cache": "4.1.1", 1432 | "named-placeholders": "1.1.1", 1433 | "object-assign": "4.1.1", 1434 | "readable-stream": "2.3.2", 1435 | "safe-buffer": "5.1.1", 1436 | "seq-queue": "0.0.5", 1437 | "sqlstring": "2.3.0" 1438 | }, 1439 | "dependencies": { 1440 | "readable-stream": { 1441 | "version": "2.3.2", 1442 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.2.tgz", 1443 | "integrity": "sha1-WgTfBeT1f+Pw3Gj90R3FyXx+b00=", 1444 | "requires": { 1445 | "core-util-is": "1.0.2", 1446 | "inherits": "2.0.3", 1447 | "isarray": "1.0.0", 1448 | "process-nextick-args": "1.0.7", 1449 | "safe-buffer": "5.1.1", 1450 | "string_decoder": "1.0.3", 1451 | "util-deprecate": "1.0.2" 1452 | } 1453 | } 1454 | } 1455 | }, 1456 | "named-placeholders": { 1457 | "version": "1.1.1", 1458 | "resolved": "https://registry.npmjs.org/named-placeholders/-/named-placeholders-1.1.1.tgz", 1459 | "integrity": "sha1-O3oNJiA910s6nfTJz7gnsvuQfmQ=", 1460 | "requires": { 1461 | "lru-cache": "2.5.0" 1462 | }, 1463 | "dependencies": { 1464 | "lru-cache": { 1465 | "version": "2.5.0", 1466 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-2.5.0.tgz", 1467 | "integrity": "sha1-2COIrpyWC+y+oMc7uet5tsbOmus=" 1468 | } 1469 | } 1470 | }, 1471 | "nan": { 1472 | "version": "2.6.2", 1473 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.6.2.tgz", 1474 | "integrity": "sha1-5P805slf37WuzAjeZZb0NgWn20U=" 1475 | }, 1476 | "negotiator": { 1477 | "version": "0.6.1", 1478 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1479 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 1480 | }, 1481 | "next-tick": { 1482 | "version": "1.0.0", 1483 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.0.0.tgz", 1484 | "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=" 1485 | }, 1486 | "node-pre-gyp": { 1487 | "version": "0.6.36", 1488 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.6.36.tgz", 1489 | "integrity": "sha1-22BBEst04NR3VU6bUFsXq936t4Y=", 1490 | "requires": { 1491 | "mkdirp": "0.5.1", 1492 | "nopt": "4.0.1", 1493 | "npmlog": "4.1.2", 1494 | "rc": "1.2.2", 1495 | "request": "2.83.0", 1496 | "rimraf": "2.6.2", 1497 | "semver": "5.4.1", 1498 | "tar": "2.2.1", 1499 | "tar-pack": "3.4.0" 1500 | } 1501 | }, 1502 | "nopt": { 1503 | "version": "4.0.1", 1504 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", 1505 | "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", 1506 | "requires": { 1507 | "abbrev": "1.1.1", 1508 | "osenv": "0.1.4" 1509 | } 1510 | }, 1511 | "normalize-package-data": { 1512 | "version": "2.4.0", 1513 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 1514 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 1515 | "requires": { 1516 | "hosted-git-info": "2.5.0", 1517 | "is-builtin-module": "1.0.0", 1518 | "semver": "5.4.1", 1519 | "validate-npm-package-license": "3.0.1" 1520 | } 1521 | }, 1522 | "npm-run-path": { 1523 | "version": "2.0.2", 1524 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1525 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1526 | "requires": { 1527 | "path-key": "2.0.1" 1528 | } 1529 | }, 1530 | "npmlog": { 1531 | "version": "4.1.2", 1532 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1533 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1534 | "requires": { 1535 | "are-we-there-yet": "1.1.4", 1536 | "console-control-strings": "1.1.0", 1537 | "gauge": "2.7.4", 1538 | "set-blocking": "2.0.0" 1539 | } 1540 | }, 1541 | "number-is-nan": { 1542 | "version": "1.0.1", 1543 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1544 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1545 | }, 1546 | "oauth-sign": { 1547 | "version": "0.8.2", 1548 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", 1549 | "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=" 1550 | }, 1551 | "object-assign": { 1552 | "version": "4.1.1", 1553 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1554 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1555 | }, 1556 | "on-finished": { 1557 | "version": "2.3.0", 1558 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1559 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1560 | "requires": { 1561 | "ee-first": "1.1.1" 1562 | } 1563 | }, 1564 | "on-headers": { 1565 | "version": "1.0.1", 1566 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.1.tgz", 1567 | "integrity": "sha1-ko9dD0cNSTQmUepnlLCFfBAGk/c=" 1568 | }, 1569 | "once": { 1570 | "version": "1.4.0", 1571 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1572 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1573 | "requires": { 1574 | "wrappy": "1.0.2" 1575 | } 1576 | }, 1577 | "optimist": { 1578 | "version": "0.3.7", 1579 | "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.3.7.tgz", 1580 | "integrity": "sha1-yQlBrVnkJzMokjB00s8ufLxuwNk=", 1581 | "requires": { 1582 | "wordwrap": "0.0.3" 1583 | } 1584 | }, 1585 | "os-homedir": { 1586 | "version": "1.0.2", 1587 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1588 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1589 | }, 1590 | "os-locale": { 1591 | "version": "2.1.0", 1592 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-2.1.0.tgz", 1593 | "integrity": "sha512-3sslG3zJbEYcaC4YVAvDorjGxc7tv6KVATnLPZONiljsUncvihe9BQoVCEs0RZ1kmf4Hk9OBqlZfJZWI4GanKA==", 1594 | "requires": { 1595 | "execa": "0.7.0", 1596 | "lcid": "1.0.0", 1597 | "mem": "1.1.0" 1598 | } 1599 | }, 1600 | "os-tmpdir": { 1601 | "version": "1.0.2", 1602 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1603 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1604 | }, 1605 | "osenv": { 1606 | "version": "0.1.4", 1607 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.4.tgz", 1608 | "integrity": "sha1-Qv5tWVPfBsgGS+bxdsPQWqqjRkQ=", 1609 | "requires": { 1610 | "os-homedir": "1.0.2", 1611 | "os-tmpdir": "1.0.2" 1612 | } 1613 | }, 1614 | "p-finally": { 1615 | "version": "1.0.0", 1616 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1617 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" 1618 | }, 1619 | "p-limit": { 1620 | "version": "1.1.0", 1621 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.1.0.tgz", 1622 | "integrity": "sha1-sH/y2aXYi+yAYDWJWiurZqJ5iLw=" 1623 | }, 1624 | "p-locate": { 1625 | "version": "2.0.0", 1626 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1627 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1628 | "requires": { 1629 | "p-limit": "1.1.0" 1630 | } 1631 | }, 1632 | "parse-error": { 1633 | "version": "0.2.0", 1634 | "resolved": "https://registry.npmjs.org/parse-error/-/parse-error-0.2.0.tgz", 1635 | "integrity": "sha1-ojbVB2y+GWwVeBuJKyDQtpdZ/1s=" 1636 | }, 1637 | "parse-json": { 1638 | "version": "2.2.0", 1639 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1640 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1641 | "requires": { 1642 | "error-ex": "1.3.1" 1643 | } 1644 | }, 1645 | "parseurl": { 1646 | "version": "1.3.2", 1647 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 1648 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 1649 | }, 1650 | "passport": { 1651 | "version": "0.4.0", 1652 | "resolved": "https://registry.npmjs.org/passport/-/passport-0.4.0.tgz", 1653 | "integrity": "sha1-xQlWkTR71a07XhgCOMORTRbwWBE=", 1654 | "requires": { 1655 | "passport-strategy": "1.0.0", 1656 | "pause": "0.0.1" 1657 | } 1658 | }, 1659 | "passport-jwt": { 1660 | "version": "3.0.0", 1661 | "resolved": "https://registry.npmjs.org/passport-jwt/-/passport-jwt-3.0.0.tgz", 1662 | "integrity": "sha1-fZ5P8PoFIhCFQM4fz6g7vY+qKck=", 1663 | "requires": { 1664 | "jsonwebtoken": "7.4.3", 1665 | "passport-strategy": "1.0.0" 1666 | } 1667 | }, 1668 | "passport-strategy": { 1669 | "version": "1.0.0", 1670 | "resolved": "https://registry.npmjs.org/passport-strategy/-/passport-strategy-1.0.0.tgz", 1671 | "integrity": "sha1-tVOaqPwiWj0a0XlHbd8ja0QPUuQ=" 1672 | }, 1673 | "path-exists": { 1674 | "version": "3.0.0", 1675 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1676 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" 1677 | }, 1678 | "path-is-absolute": { 1679 | "version": "1.0.1", 1680 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1681 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1682 | }, 1683 | "path-key": { 1684 | "version": "2.0.1", 1685 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1686 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 1687 | }, 1688 | "path-parse": { 1689 | "version": "1.0.5", 1690 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", 1691 | "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=" 1692 | }, 1693 | "path-to-regexp": { 1694 | "version": "0.1.7", 1695 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1696 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1697 | }, 1698 | "path-type": { 1699 | "version": "2.0.0", 1700 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1701 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1702 | "requires": { 1703 | "pify": "2.3.0" 1704 | } 1705 | }, 1706 | "pause": { 1707 | "version": "0.0.1", 1708 | "resolved": "https://registry.npmjs.org/pause/-/pause-0.0.1.tgz", 1709 | "integrity": "sha1-HUCLP9t2kjuVQ9lvtMnf1TXZy10=" 1710 | }, 1711 | "performance-now": { 1712 | "version": "2.1.0", 1713 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1714 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 1715 | }, 1716 | "pify": { 1717 | "version": "2.3.0", 1718 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1719 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" 1720 | }, 1721 | "process-nextick-args": { 1722 | "version": "1.0.7", 1723 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 1724 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" 1725 | }, 1726 | "promise": { 1727 | "version": "6.1.0", 1728 | "resolved": "https://registry.npmjs.org/promise/-/promise-6.1.0.tgz", 1729 | "integrity": "sha1-LOcp9rlLRcJoka0GAsXJDgTG7vY=", 1730 | "requires": { 1731 | "asap": "1.0.0" 1732 | } 1733 | }, 1734 | "proto-list": { 1735 | "version": "1.2.4", 1736 | "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", 1737 | "integrity": "sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk=" 1738 | }, 1739 | "proxy-addr": { 1740 | "version": "1.1.5", 1741 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.5.tgz", 1742 | "integrity": "sha1-ccDuOxAt4/IC87ZPYI0XP8uhqRg=", 1743 | "requires": { 1744 | "forwarded": "0.1.2", 1745 | "ipaddr.js": "1.4.0" 1746 | } 1747 | }, 1748 | "pseudomap": { 1749 | "version": "1.0.2", 1750 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1751 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 1752 | }, 1753 | "punycode": { 1754 | "version": "1.4.1", 1755 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1756 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 1757 | }, 1758 | "qs": { 1759 | "version": "6.5.1", 1760 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 1761 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 1762 | }, 1763 | "range-parser": { 1764 | "version": "1.2.0", 1765 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 1766 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 1767 | }, 1768 | "raw-body": { 1769 | "version": "2.3.2", 1770 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.2.tgz", 1771 | "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=", 1772 | "requires": { 1773 | "bytes": "3.0.0", 1774 | "http-errors": "1.6.2", 1775 | "iconv-lite": "0.4.19", 1776 | "unpipe": "1.0.0" 1777 | } 1778 | }, 1779 | "rc": { 1780 | "version": "1.2.2", 1781 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.2.tgz", 1782 | "integrity": "sha1-2M6ctX6NZNnHut2YdsfDTL48cHc=", 1783 | "requires": { 1784 | "deep-extend": "0.4.2", 1785 | "ini": "1.3.4", 1786 | "minimist": "1.2.0", 1787 | "strip-json-comments": "2.0.1" 1788 | }, 1789 | "dependencies": { 1790 | "minimist": { 1791 | "version": "1.2.0", 1792 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1793 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" 1794 | } 1795 | } 1796 | }, 1797 | "read-pkg": { 1798 | "version": "2.0.0", 1799 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1800 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1801 | "requires": { 1802 | "load-json-file": "2.0.0", 1803 | "normalize-package-data": "2.4.0", 1804 | "path-type": "2.0.0" 1805 | } 1806 | }, 1807 | "read-pkg-up": { 1808 | "version": "2.0.0", 1809 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1810 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1811 | "requires": { 1812 | "find-up": "2.1.0", 1813 | "read-pkg": "2.0.0" 1814 | } 1815 | }, 1816 | "readable-stream": { 1817 | "version": "2.2.7", 1818 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz", 1819 | "integrity": "sha1-BwV6y+JGeyIELTb5jFrVBwVOlbE=", 1820 | "requires": { 1821 | "buffer-shims": "1.0.0", 1822 | "core-util-is": "1.0.2", 1823 | "inherits": "2.0.3", 1824 | "isarray": "1.0.0", 1825 | "process-nextick-args": "1.0.7", 1826 | "string_decoder": "1.0.3", 1827 | "util-deprecate": "1.0.2" 1828 | } 1829 | }, 1830 | "redeyed": { 1831 | "version": "1.0.1", 1832 | "resolved": "https://registry.npmjs.org/redeyed/-/redeyed-1.0.1.tgz", 1833 | "integrity": "sha1-6WwZO0DAgWsArshCaY5hGF5VSYo=", 1834 | "requires": { 1835 | "esprima": "3.0.0" 1836 | } 1837 | }, 1838 | "regenerator-runtime": { 1839 | "version": "0.11.0", 1840 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.0.tgz", 1841 | "integrity": "sha512-/aA0kLeRb5N9K0d4fw7ooEbI+xDe+DKD499EQqygGqeS8N3xto15p09uY2xj7ixP81sNPXvRLnAQIqdVStgb1A==" 1842 | }, 1843 | "repeat-string": { 1844 | "version": "1.6.1", 1845 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 1846 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" 1847 | }, 1848 | "request": { 1849 | "version": "2.83.0", 1850 | "resolved": "https://registry.npmjs.org/request/-/request-2.83.0.tgz", 1851 | "integrity": "sha512-lR3gD69osqm6EYLk9wB/G1W/laGWjzH90t1vEa2xuxHD5KUrSzp9pUSfTm+YC5Nxt2T8nMPEvKlhbQayU7bgFw==", 1852 | "requires": { 1853 | "aws-sign2": "0.7.0", 1854 | "aws4": "1.6.0", 1855 | "caseless": "0.12.0", 1856 | "combined-stream": "1.0.5", 1857 | "extend": "3.0.1", 1858 | "forever-agent": "0.6.1", 1859 | "form-data": "2.3.1", 1860 | "har-validator": "5.0.3", 1861 | "hawk": "6.0.2", 1862 | "http-signature": "1.2.0", 1863 | "is-typedarray": "1.0.0", 1864 | "isstream": "0.1.2", 1865 | "json-stringify-safe": "5.0.1", 1866 | "mime-types": "2.1.17", 1867 | "oauth-sign": "0.8.2", 1868 | "performance-now": "2.1.0", 1869 | "qs": "6.5.1", 1870 | "safe-buffer": "5.1.1", 1871 | "stringstream": "0.0.5", 1872 | "tough-cookie": "2.3.3", 1873 | "tunnel-agent": "0.6.0", 1874 | "uuid": "3.1.0" 1875 | } 1876 | }, 1877 | "require-directory": { 1878 | "version": "2.1.1", 1879 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1880 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" 1881 | }, 1882 | "require-main-filename": { 1883 | "version": "1.0.1", 1884 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", 1885 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=" 1886 | }, 1887 | "resolve": { 1888 | "version": "1.5.0", 1889 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.5.0.tgz", 1890 | "integrity": "sha512-hgoSGrc3pjzAPHNBg+KnFcK2HwlHTs/YrAGUr6qgTVUZmXv1UEXXl0bZNBKMA9fud6lRYFdPGz0xXxycPzmmiw==", 1891 | "requires": { 1892 | "path-parse": "1.0.5" 1893 | } 1894 | }, 1895 | "retry-as-promised": { 1896 | "version": "2.3.2", 1897 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-2.3.2.tgz", 1898 | "integrity": "sha1-zZdO5P2bX+A8vzGHHuSCIcB3N7c=", 1899 | "requires": { 1900 | "bluebird": "3.5.1", 1901 | "debug": "2.6.9" 1902 | } 1903 | }, 1904 | "right-align": { 1905 | "version": "0.1.3", 1906 | "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", 1907 | "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", 1908 | "requires": { 1909 | "align-text": "0.1.4" 1910 | } 1911 | }, 1912 | "rimraf": { 1913 | "version": "2.6.2", 1914 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 1915 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 1916 | "requires": { 1917 | "glob": "7.1.2" 1918 | } 1919 | }, 1920 | "safe-buffer": { 1921 | "version": "5.1.1", 1922 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 1923 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 1924 | }, 1925 | "semver": { 1926 | "version": "5.4.1", 1927 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", 1928 | "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==" 1929 | }, 1930 | "send": { 1931 | "version": "0.15.6", 1932 | "resolved": "https://registry.npmjs.org/send/-/send-0.15.6.tgz", 1933 | "integrity": "sha1-IPI6nJJbdiq4JwX+L52yUqzkfjQ=", 1934 | "requires": { 1935 | "debug": "2.6.9", 1936 | "depd": "1.1.1", 1937 | "destroy": "1.0.4", 1938 | "encodeurl": "1.0.1", 1939 | "escape-html": "1.0.3", 1940 | "etag": "1.8.1", 1941 | "fresh": "0.5.2", 1942 | "http-errors": "1.6.2", 1943 | "mime": "1.3.4", 1944 | "ms": "2.0.0", 1945 | "on-finished": "2.3.0", 1946 | "range-parser": "1.2.0", 1947 | "statuses": "1.3.1" 1948 | }, 1949 | "dependencies": { 1950 | "statuses": { 1951 | "version": "1.3.1", 1952 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 1953 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 1954 | } 1955 | } 1956 | }, 1957 | "seq-queue": { 1958 | "version": "0.0.5", 1959 | "resolved": "https://registry.npmjs.org/seq-queue/-/seq-queue-0.0.5.tgz", 1960 | "integrity": "sha1-1WgS4cAXpuTnw+Ojeh2m143TyT4=" 1961 | }, 1962 | "sequelize": { 1963 | "version": "4.31.2", 1964 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-4.31.2.tgz", 1965 | "integrity": "sha512-ldbh1tNPpeFZ30bWAW0HqW2rinjmCmvb2lqRQ/TxhjIT70ypnQzFhBjXeIxZDFtov5koaw9NTbaOwJQn8nkYgA==", 1966 | "requires": { 1967 | "bluebird": "3.5.1", 1968 | "cls-bluebird": "2.1.0", 1969 | "debug": "3.1.0", 1970 | "depd": "1.1.1", 1971 | "dottie": "2.0.0", 1972 | "generic-pool": "3.4.0", 1973 | "inflection": "1.12.0", 1974 | "lodash": "4.17.4", 1975 | "moment": "2.19.1", 1976 | "moment-timezone": "0.5.14", 1977 | "retry-as-promised": "2.3.2", 1978 | "semver": "5.4.1", 1979 | "terraformer-wkt-parser": "1.1.2", 1980 | "toposort-class": "1.0.1", 1981 | "uuid": "3.1.0", 1982 | "validator": "9.2.0", 1983 | "wkx": "0.4.2" 1984 | }, 1985 | "dependencies": { 1986 | "debug": { 1987 | "version": "3.1.0", 1988 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1989 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1990 | "requires": { 1991 | "ms": "2.0.0" 1992 | } 1993 | } 1994 | } 1995 | }, 1996 | "sequelize-cli": { 1997 | "version": "3.0.0", 1998 | "resolved": "https://registry.npmjs.org/sequelize-cli/-/sequelize-cli-3.0.0.tgz", 1999 | "integrity": "sha1-W61ruD8jOSMIMAdUOzgYKsNke/k=", 2000 | "requires": { 2001 | "bluebird": "3.5.1", 2002 | "cli-color": "1.2.0", 2003 | "fs-extra": "4.0.2", 2004 | "js-beautify": "1.7.4", 2005 | "lodash": "4.17.4", 2006 | "resolve": "1.5.0", 2007 | "umzug": "2.1.0", 2008 | "yargs": "8.0.2" 2009 | }, 2010 | "dependencies": { 2011 | "ansi-regex": { 2012 | "version": "3.0.0", 2013 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 2014 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 2015 | }, 2016 | "camelcase": { 2017 | "version": "4.1.0", 2018 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 2019 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=" 2020 | }, 2021 | "cliui": { 2022 | "version": "3.2.0", 2023 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", 2024 | "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", 2025 | "requires": { 2026 | "string-width": "1.0.2", 2027 | "strip-ansi": "3.0.1", 2028 | "wrap-ansi": "2.1.0" 2029 | }, 2030 | "dependencies": { 2031 | "string-width": { 2032 | "version": "1.0.2", 2033 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 2034 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 2035 | "requires": { 2036 | "code-point-at": "1.1.0", 2037 | "is-fullwidth-code-point": "1.0.0", 2038 | "strip-ansi": "3.0.1" 2039 | } 2040 | } 2041 | } 2042 | }, 2043 | "string-width": { 2044 | "version": "2.1.1", 2045 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2046 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2047 | "requires": { 2048 | "is-fullwidth-code-point": "2.0.0", 2049 | "strip-ansi": "4.0.0" 2050 | }, 2051 | "dependencies": { 2052 | "is-fullwidth-code-point": { 2053 | "version": "2.0.0", 2054 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2055 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 2056 | }, 2057 | "strip-ansi": { 2058 | "version": "4.0.0", 2059 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2060 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2061 | "requires": { 2062 | "ansi-regex": "3.0.0" 2063 | } 2064 | } 2065 | } 2066 | }, 2067 | "yargs": { 2068 | "version": "8.0.2", 2069 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-8.0.2.tgz", 2070 | "integrity": "sha1-YpmpBVsc78lp/355wdkY3Osiw2A=", 2071 | "requires": { 2072 | "camelcase": "4.1.0", 2073 | "cliui": "3.2.0", 2074 | "decamelize": "1.2.0", 2075 | "get-caller-file": "1.0.2", 2076 | "os-locale": "2.1.0", 2077 | "read-pkg-up": "2.0.0", 2078 | "require-directory": "2.1.1", 2079 | "require-main-filename": "1.0.1", 2080 | "set-blocking": "2.0.0", 2081 | "string-width": "2.1.1", 2082 | "which-module": "2.0.0", 2083 | "y18n": "3.2.1", 2084 | "yargs-parser": "7.0.0" 2085 | } 2086 | } 2087 | } 2088 | }, 2089 | "serve-favicon": { 2090 | "version": "2.4.5", 2091 | "resolved": "https://registry.npmjs.org/serve-favicon/-/serve-favicon-2.4.5.tgz", 2092 | "integrity": "sha512-s7F8h2NrslMkG50KxvlGdj+ApSwaLex0vexuJ9iFf3GLTIp1ph/l1qZvRe9T9TJEYZgmq72ZwJ2VYiAEtChknw==", 2093 | "requires": { 2094 | "etag": "1.8.1", 2095 | "fresh": "0.5.2", 2096 | "ms": "2.0.0", 2097 | "parseurl": "1.3.2", 2098 | "safe-buffer": "5.1.1" 2099 | } 2100 | }, 2101 | "serve-static": { 2102 | "version": "1.12.6", 2103 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.12.6.tgz", 2104 | "integrity": "sha1-uXN3P2NEmTTaVOW+ul4x2fQhFXc=", 2105 | "requires": { 2106 | "encodeurl": "1.0.1", 2107 | "escape-html": "1.0.3", 2108 | "parseurl": "1.3.2", 2109 | "send": "0.15.6" 2110 | } 2111 | }, 2112 | "set-blocking": { 2113 | "version": "2.0.0", 2114 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2115 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 2116 | }, 2117 | "setprototypeof": { 2118 | "version": "1.0.3", 2119 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 2120 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 2121 | }, 2122 | "shebang-command": { 2123 | "version": "1.2.0", 2124 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2125 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2126 | "requires": { 2127 | "shebang-regex": "1.0.0" 2128 | } 2129 | }, 2130 | "shebang-regex": { 2131 | "version": "1.0.0", 2132 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2133 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 2134 | }, 2135 | "shimmer": { 2136 | "version": "1.2.0", 2137 | "resolved": "https://registry.npmjs.org/shimmer/-/shimmer-1.2.0.tgz", 2138 | "integrity": "sha512-xTCx2vohXC2EWWDqY/zb4+5Mu28D+HYNSOuFzsyRDRvI/e1ICb69afwaUwfjr+25ZXldbOLyp+iDUZHq8UnTag==" 2139 | }, 2140 | "sigmund": { 2141 | "version": "1.0.1", 2142 | "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", 2143 | "integrity": "sha1-P/IfGYytIXX587eBhT/ZTQ0ZtZA=" 2144 | }, 2145 | "signal-exit": { 2146 | "version": "3.0.2", 2147 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2148 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 2149 | }, 2150 | "sntp": { 2151 | "version": "2.0.2", 2152 | "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.0.2.tgz", 2153 | "integrity": "sha1-UGQRDwr4X3z9t9a2ekACjOUrSys=", 2154 | "requires": { 2155 | "hoek": "4.2.0" 2156 | } 2157 | }, 2158 | "source-map": { 2159 | "version": "0.4.4", 2160 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", 2161 | "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", 2162 | "requires": { 2163 | "amdefine": "1.0.1" 2164 | } 2165 | }, 2166 | "spdx-correct": { 2167 | "version": "1.0.2", 2168 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-1.0.2.tgz", 2169 | "integrity": "sha1-SzBz2TP/UfORLwOsVRlJikFQ20A=", 2170 | "requires": { 2171 | "spdx-license-ids": "1.2.2" 2172 | } 2173 | }, 2174 | "spdx-expression-parse": { 2175 | "version": "1.0.4", 2176 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz", 2177 | "integrity": "sha1-m98vIOH0DtRH++JzJmGR/O1RYmw=" 2178 | }, 2179 | "spdx-license-ids": { 2180 | "version": "1.2.2", 2181 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz", 2182 | "integrity": "sha1-yd96NCRZSt5r0RkA1ZZpbcBrrFc=" 2183 | }, 2184 | "sqlstring": { 2185 | "version": "2.3.0", 2186 | "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.0.tgz", 2187 | "integrity": "sha1-UluKT9Jtb3GqYegipsr5dtMa0qg=" 2188 | }, 2189 | "sshpk": { 2190 | "version": "1.13.1", 2191 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", 2192 | "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", 2193 | "requires": { 2194 | "asn1": "0.2.3", 2195 | "assert-plus": "1.0.0", 2196 | "bcrypt-pbkdf": "1.0.1", 2197 | "dashdash": "1.14.1", 2198 | "ecc-jsbn": "0.1.1", 2199 | "getpass": "0.1.7", 2200 | "jsbn": "0.1.1", 2201 | "tweetnacl": "0.14.5" 2202 | } 2203 | }, 2204 | "statuses": { 2205 | "version": "1.4.0", 2206 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 2207 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 2208 | }, 2209 | "string-width": { 2210 | "version": "1.0.2", 2211 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 2212 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 2213 | "requires": { 2214 | "code-point-at": "1.1.0", 2215 | "is-fullwidth-code-point": "1.0.0", 2216 | "strip-ansi": "3.0.1" 2217 | } 2218 | }, 2219 | "string_decoder": { 2220 | "version": "1.0.3", 2221 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 2222 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 2223 | "requires": { 2224 | "safe-buffer": "5.1.1" 2225 | } 2226 | }, 2227 | "stringstream": { 2228 | "version": "0.0.5", 2229 | "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", 2230 | "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=" 2231 | }, 2232 | "strip-ansi": { 2233 | "version": "3.0.1", 2234 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2235 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2236 | "requires": { 2237 | "ansi-regex": "2.1.1" 2238 | } 2239 | }, 2240 | "strip-bom": { 2241 | "version": "3.0.0", 2242 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2243 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=" 2244 | }, 2245 | "strip-eof": { 2246 | "version": "1.0.0", 2247 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 2248 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" 2249 | }, 2250 | "strip-json-comments": { 2251 | "version": "2.0.1", 2252 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2253 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 2254 | }, 2255 | "tar": { 2256 | "version": "2.2.1", 2257 | "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", 2258 | "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", 2259 | "requires": { 2260 | "block-stream": "0.0.9", 2261 | "fstream": "1.0.11", 2262 | "inherits": "2.0.3" 2263 | } 2264 | }, 2265 | "tar-pack": { 2266 | "version": "3.4.0", 2267 | "resolved": "https://registry.npmjs.org/tar-pack/-/tar-pack-3.4.0.tgz", 2268 | "integrity": "sha1-I74tf2cagzk3bL2wuP4/3r8xeYQ=", 2269 | "requires": { 2270 | "debug": "2.6.9", 2271 | "fstream": "1.0.11", 2272 | "fstream-ignore": "1.0.5", 2273 | "once": "1.4.0", 2274 | "readable-stream": "2.2.7", 2275 | "rimraf": "2.6.2", 2276 | "tar": "2.2.1", 2277 | "uid-number": "0.0.6" 2278 | } 2279 | }, 2280 | "terraformer": { 2281 | "version": "1.0.8", 2282 | "resolved": "https://registry.npmjs.org/terraformer/-/terraformer-1.0.8.tgz", 2283 | "integrity": "sha1-UeCtiXRvzyFh3G9lqnDkI3fItZM=", 2284 | "requires": { 2285 | "@types/geojson": "1.0.6" 2286 | } 2287 | }, 2288 | "terraformer-wkt-parser": { 2289 | "version": "1.1.2", 2290 | "resolved": "https://registry.npmjs.org/terraformer-wkt-parser/-/terraformer-wkt-parser-1.1.2.tgz", 2291 | "integrity": "sha1-M2oMj8gglKWv+DKI9prt7NNpvww=", 2292 | "requires": { 2293 | "terraformer": "1.0.8" 2294 | } 2295 | }, 2296 | "timers-ext": { 2297 | "version": "0.1.2", 2298 | "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.2.tgz", 2299 | "integrity": "sha1-YcxHp2wavTGV8UUn+XjViulMUgQ=", 2300 | "requires": { 2301 | "es5-ext": "0.10.35", 2302 | "next-tick": "1.0.0" 2303 | } 2304 | }, 2305 | "topo": { 2306 | "version": "1.1.0", 2307 | "resolved": "https://registry.npmjs.org/topo/-/topo-1.1.0.tgz", 2308 | "integrity": "sha1-6ddRYV0buH3IZdsYL6HKCl71NtU=", 2309 | "requires": { 2310 | "hoek": "2.16.3" 2311 | }, 2312 | "dependencies": { 2313 | "hoek": { 2314 | "version": "2.16.3", 2315 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", 2316 | "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=" 2317 | } 2318 | } 2319 | }, 2320 | "toposort-class": { 2321 | "version": "1.0.1", 2322 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 2323 | "integrity": "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg=" 2324 | }, 2325 | "tough-cookie": { 2326 | "version": "2.3.3", 2327 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.3.tgz", 2328 | "integrity": "sha1-C2GKVWW23qkL80JdBNVe3EdadWE=", 2329 | "requires": { 2330 | "punycode": "1.4.1" 2331 | } 2332 | }, 2333 | "transformers": { 2334 | "version": "2.1.0", 2335 | "resolved": "https://registry.npmjs.org/transformers/-/transformers-2.1.0.tgz", 2336 | "integrity": "sha1-XSPLNVYd2F3Gf7hIIwm0fVPM6ac=", 2337 | "requires": { 2338 | "css": "1.0.8", 2339 | "promise": "2.0.0", 2340 | "uglify-js": "2.2.5" 2341 | }, 2342 | "dependencies": { 2343 | "is-promise": { 2344 | "version": "1.0.1", 2345 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-1.0.1.tgz", 2346 | "integrity": "sha1-MVc3YcBX4zwukaq56W2gjO++duU=" 2347 | }, 2348 | "promise": { 2349 | "version": "2.0.0", 2350 | "resolved": "https://registry.npmjs.org/promise/-/promise-2.0.0.tgz", 2351 | "integrity": "sha1-RmSKqdYFr10ucMMCS/WUNtoCuA4=", 2352 | "requires": { 2353 | "is-promise": "1.0.1" 2354 | } 2355 | }, 2356 | "source-map": { 2357 | "version": "0.1.43", 2358 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.43.tgz", 2359 | "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", 2360 | "requires": { 2361 | "amdefine": "1.0.1" 2362 | } 2363 | }, 2364 | "uglify-js": { 2365 | "version": "2.2.5", 2366 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.2.5.tgz", 2367 | "integrity": "sha1-puAqcNg5eSuXgEiLe4sYTAlcmcc=", 2368 | "requires": { 2369 | "optimist": "0.3.7", 2370 | "source-map": "0.1.43" 2371 | } 2372 | } 2373 | } 2374 | }, 2375 | "tunnel-agent": { 2376 | "version": "0.6.0", 2377 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 2378 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 2379 | "requires": { 2380 | "safe-buffer": "5.1.1" 2381 | } 2382 | }, 2383 | "tweetnacl": { 2384 | "version": "0.14.5", 2385 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 2386 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 2387 | "optional": true 2388 | }, 2389 | "type-is": { 2390 | "version": "1.6.15", 2391 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz", 2392 | "integrity": "sha1-yrEPtJCeRByChC6v4a1kbIGARBA=", 2393 | "requires": { 2394 | "media-typer": "0.3.0", 2395 | "mime-types": "2.1.17" 2396 | } 2397 | }, 2398 | "uglify-js": { 2399 | "version": "2.8.29", 2400 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", 2401 | "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", 2402 | "requires": { 2403 | "source-map": "0.5.7", 2404 | "uglify-to-browserify": "1.0.2", 2405 | "yargs": "3.10.0" 2406 | }, 2407 | "dependencies": { 2408 | "source-map": { 2409 | "version": "0.5.7", 2410 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2411 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" 2412 | } 2413 | } 2414 | }, 2415 | "uglify-to-browserify": { 2416 | "version": "1.0.2", 2417 | "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", 2418 | "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", 2419 | "optional": true 2420 | }, 2421 | "uid-number": { 2422 | "version": "0.0.6", 2423 | "resolved": "https://registry.npmjs.org/uid-number/-/uid-number-0.0.6.tgz", 2424 | "integrity": "sha1-DqEOgDXo61uOREnwbaHHMGY7qoE=" 2425 | }, 2426 | "umzug": { 2427 | "version": "2.1.0", 2428 | "resolved": "https://registry.npmjs.org/umzug/-/umzug-2.1.0.tgz", 2429 | "integrity": "sha512-BgT+ekpItEWaG+3JjLLj6yVTxw2wIH8Cr6JyKYIzukWAx9nzGhC6BGHb/IRMjpobMM1qtIrReATwLUjKpU2iOQ==", 2430 | "requires": { 2431 | "babel-runtime": "6.26.0", 2432 | "bluebird": "3.5.1", 2433 | "lodash": "4.17.4", 2434 | "resolve": "1.5.0" 2435 | } 2436 | }, 2437 | "universalify": { 2438 | "version": "0.1.1", 2439 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.1.tgz", 2440 | "integrity": "sha1-+nG63UQ3r0wUiEHjs7Fl+enlkLc=" 2441 | }, 2442 | "unpipe": { 2443 | "version": "1.0.0", 2444 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2445 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2446 | }, 2447 | "util-deprecate": { 2448 | "version": "1.0.2", 2449 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2450 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2451 | }, 2452 | "utils-merge": { 2453 | "version": "1.0.0", 2454 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", 2455 | "integrity": "sha1-ApT7kiu5N1FTVBxPcJYjHyh8ivg=" 2456 | }, 2457 | "uuid": { 2458 | "version": "3.1.0", 2459 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 2460 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 2461 | }, 2462 | "validate-npm-package-license": { 2463 | "version": "3.0.1", 2464 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz", 2465 | "integrity": "sha1-KAS6vnEq0zeUWaz74kdGqywwP7w=", 2466 | "requires": { 2467 | "spdx-correct": "1.0.2", 2468 | "spdx-expression-parse": "1.0.4" 2469 | } 2470 | }, 2471 | "validator": { 2472 | "version": "9.2.0", 2473 | "resolved": "https://registry.npmjs.org/validator/-/validator-9.2.0.tgz", 2474 | "integrity": "sha512-6Ij4Eo0KM4LkR0d0IegOwluG5453uqT5QyF5SV5Ezvm8/zmkKI/L4eoraafZGlZPC9guLkwKzgypcw8VGWWnGA==" 2475 | }, 2476 | "vary": { 2477 | "version": "1.1.2", 2478 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2479 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2480 | }, 2481 | "verror": { 2482 | "version": "1.10.0", 2483 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2484 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2485 | "requires": { 2486 | "assert-plus": "1.0.0", 2487 | "core-util-is": "1.0.2", 2488 | "extsprintf": "1.3.0" 2489 | } 2490 | }, 2491 | "void-elements": { 2492 | "version": "2.0.1", 2493 | "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-2.0.1.tgz", 2494 | "integrity": "sha1-wGavtYK7HLQSjWDqkjkulNXp2+w=" 2495 | }, 2496 | "which": { 2497 | "version": "1.3.0", 2498 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 2499 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 2500 | "requires": { 2501 | "isexe": "2.0.0" 2502 | } 2503 | }, 2504 | "which-module": { 2505 | "version": "2.0.0", 2506 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 2507 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" 2508 | }, 2509 | "wide-align": { 2510 | "version": "1.1.2", 2511 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.2.tgz", 2512 | "integrity": "sha512-ijDLlyQ7s6x1JgCLur53osjm/UXUYD9+0PbYKrBsYisYXzCxN+HC3mYDNy/dWdmf3AwqwU3CXwDCvsNgGK1S0w==", 2513 | "requires": { 2514 | "string-width": "1.0.2" 2515 | } 2516 | }, 2517 | "window-size": { 2518 | "version": "0.1.0", 2519 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz", 2520 | "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=" 2521 | }, 2522 | "with": { 2523 | "version": "4.0.3", 2524 | "resolved": "https://registry.npmjs.org/with/-/with-4.0.3.tgz", 2525 | "integrity": "sha1-7v0VTp550sjTQXtkeo8U2f7M4U4=", 2526 | "requires": { 2527 | "acorn": "1.2.2", 2528 | "acorn-globals": "1.0.9" 2529 | }, 2530 | "dependencies": { 2531 | "acorn": { 2532 | "version": "1.2.2", 2533 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-1.2.2.tgz", 2534 | "integrity": "sha1-yM4n3grMdtiW0rH6099YjZ6C8BQ=" 2535 | } 2536 | } 2537 | }, 2538 | "wkx": { 2539 | "version": "0.4.2", 2540 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.4.2.tgz", 2541 | "integrity": "sha1-d201pjSlwi5lbkdEvetU+D/Szo0=", 2542 | "requires": { 2543 | "@types/node": "9.3.0" 2544 | } 2545 | }, 2546 | "wordwrap": { 2547 | "version": "0.0.3", 2548 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", 2549 | "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=" 2550 | }, 2551 | "wrap-ansi": { 2552 | "version": "2.1.0", 2553 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 2554 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 2555 | "requires": { 2556 | "string-width": "1.0.2", 2557 | "strip-ansi": "3.0.1" 2558 | } 2559 | }, 2560 | "wrappy": { 2561 | "version": "1.0.2", 2562 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2563 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2564 | }, 2565 | "xtend": { 2566 | "version": "4.0.1", 2567 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2568 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" 2569 | }, 2570 | "y18n": { 2571 | "version": "3.2.1", 2572 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", 2573 | "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=" 2574 | }, 2575 | "yallist": { 2576 | "version": "2.1.2", 2577 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 2578 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 2579 | }, 2580 | "yargs": { 2581 | "version": "3.10.0", 2582 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz", 2583 | "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", 2584 | "requires": { 2585 | "camelcase": "1.2.1", 2586 | "cliui": "2.1.0", 2587 | "decamelize": "1.2.0", 2588 | "window-size": "0.1.0" 2589 | } 2590 | }, 2591 | "yargs-parser": { 2592 | "version": "7.0.0", 2593 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-7.0.0.tgz", 2594 | "integrity": "sha1-jQrELxbqVd69MyyvTEA4s+P139k=", 2595 | "requires": { 2596 | "camelcase": "4.1.0" 2597 | }, 2598 | "dependencies": { 2599 | "camelcase": { 2600 | "version": "4.1.0", 2601 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 2602 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=" 2603 | } 2604 | } 2605 | } 2606 | } 2607 | } 2608 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "0.0.0", 4 | "private": true, 5 | "scripts": { 6 | "start": "node ./bin/www" 7 | }, 8 | "dependencies": { 9 | "await-to-js": "^2.0.1", 10 | "bcrypt": "^1.0.3", 11 | "bcrypt-promise": "^2.0.0", 12 | "body-parser": "~1.18.2", 13 | "cookie-parser": "~1.4.3", 14 | "cors": "^2.8.4", 15 | "debug": "~2.6.9", 16 | "dotenv": "^4.0.0", 17 | "express": "~4.15.5", 18 | "jade": "~1.11.0", 19 | "morgan": "~1.9.0", 20 | "mysql2": "^1.5.1", 21 | "parse-error": "^0.2.0", 22 | "passport": "^0.4.0", 23 | "passport-jwt": "^3.0.0", 24 | "sequelize": "^4.31.2", 25 | "sequelize-cli": "^3.0.0", 26 | "serve-favicon": "~2.4.5", 27 | "validator": "^9.2.0" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /public/v1/documentation/README.md: -------------------------------------------------------------------------------- 1 | Go to this site to make and edit your api doc 2 | 3 | https://editor.swagger.io//?_ga=2.73171923.1720213080.1513971186-1650799174.1513971186#/ -------------------------------------------------------------------------------- /public/v1/documentation/api.json: -------------------------------------------------------------------------------- 1 | { 2 | "swagger": "2.0", 3 | "info": { 4 | "description": "This is documentatin for the Node API. For every request you must include in the header: \n Content-Type: application/json \n\n For protected routes by authorization we use JWT. Each of these have a lock by them. Must include a Bearer Token in the header \n Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ...", 5 | "version": "1.0.0", 6 | "title": "Rest Node API mysql + JWT", 7 | "termsOfService": "http://swagger.io/terms/", 8 | "contact": { 9 | "email": "brian@orangetech.com" 10 | }, 11 | "license": { 12 | "name": "Apache 2.0", 13 | "url": "http://www.apache.org/licenses/LICENSE-2.0.html" 14 | } 15 | }, 16 | "host": "api.your-url.com", 17 | "basePath": "/v1", 18 | "tags": [ 19 | { 20 | "name": "user", 21 | "description": "Authentication and More", 22 | "externalDocs": { 23 | "description": "Find out more", 24 | "url": "http://orangetech.io" 25 | } 26 | }, 27 | { 28 | "name": "app", 29 | "description": "creation and app management" 30 | } 31 | ], 32 | "schemes": [ 33 | "http", 34 | "https" 35 | ], 36 | "paths": { 37 | "/apps": { 38 | "post": { 39 | "tags": [ 40 | "app" 41 | ], 42 | "summary": "Creates App", 43 | "description": "Creates a record of an App in our database", 44 | "operationId": "getInventory", 45 | "produces": [ 46 | "application/json" 47 | ], 48 | "parameters": [], 49 | "responses": { 50 | "200": { 51 | "description": "successful operation", 52 | "schema": { 53 | "type": "object", 54 | "additionalProperties": { 55 | "type": "integer", 56 | "format": "int32" 57 | } 58 | } 59 | }, 60 | "401": { 61 | "description": "unauthorized", 62 | "schema": { 63 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 64 | } 65 | } 66 | }, 67 | "security": [ 68 | { 69 | "api_key": [] 70 | } 71 | ] 72 | } 73 | }, 74 | "/apps/{app_id}": { 75 | "get": { 76 | "tags": [ 77 | "app" 78 | ], 79 | "summary": "Return App", 80 | "description": "Returns information about App", 81 | "produces": [ 82 | "application/json" 83 | ], 84 | "parameters": [ 85 | { 86 | "name": "app_id", 87 | "in": "path", 88 | "description": "name that need to be updated", 89 | "required": true, 90 | "type": "string" 91 | }, 92 | { 93 | "in": "body", 94 | "name": "body", 95 | "description": "Updated user object", 96 | "required": true, 97 | "schema": { 98 | "$ref": "#/definitions/CreateUser" 99 | } 100 | } 101 | ], 102 | "responses": { 103 | "200": { 104 | "description": "successful operation", 105 | "schema": { 106 | "$ref": "#/definitions/CreateUser" 107 | } 108 | }, 109 | "400": { 110 | "description": "Invalid Order" 111 | }, 112 | "401": { 113 | "description": "unauthorized", 114 | "schema": { 115 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 116 | } 117 | } 118 | }, 119 | "security": [ 120 | { 121 | "api_key": [] 122 | } 123 | ] 124 | }, 125 | "put": { 126 | "tags": [ 127 | "app" 128 | ], 129 | "summary": "Update app", 130 | "description": "Update App information", 131 | "produces": [ 132 | "application/json" 133 | ], 134 | "parameters": [ 135 | { 136 | "name": "app_id", 137 | "in": "path", 138 | "description": "name that need to be updated", 139 | "required": true, 140 | "type": "string" 141 | }, 142 | { 143 | "in": "body", 144 | "name": "body", 145 | "description": "Updated user object", 146 | "required": true, 147 | "schema": { 148 | "$ref": "#/definitions/CreateUser" 149 | } 150 | } 151 | ], 152 | "responses": { 153 | "200": { 154 | "description": "successful operation", 155 | "schema": { 156 | "$ref": "#/definitions/CreateUser" 157 | } 158 | }, 159 | "400": { 160 | "description": "Invalid Order" 161 | }, 162 | "401": { 163 | "description": "unauthorized", 164 | "schema": { 165 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 166 | } 167 | } 168 | }, 169 | "security": [ 170 | { 171 | "api_key": [] 172 | } 173 | ] 174 | }, 175 | "delete": { 176 | "tags": [ 177 | "app" 178 | ], 179 | "summary": "Soft delete app", 180 | "description": "soft delete app", 181 | "produces": [ 182 | "application/json" 183 | ], 184 | "parameters": [ 185 | { 186 | "name": "app_id", 187 | "in": "path", 188 | "description": "name that need to be updated", 189 | "required": true, 190 | "type": "string" 191 | }, 192 | { 193 | "in": "body", 194 | "name": "body", 195 | "description": "Updated user object", 196 | "required": true, 197 | "schema": { 198 | "$ref": "#/definitions/CreateUser" 199 | } 200 | } 201 | ], 202 | "responses": { 203 | "200": { 204 | "description": "successful operation", 205 | "schema": { 206 | "$ref": "#/definitions/CreateUser" 207 | } 208 | }, 209 | "400": { 210 | "description": "Invalid Order" 211 | }, 212 | "401": { 213 | "description": "unauthorized", 214 | "schema": { 215 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 216 | } 217 | } 218 | }, 219 | "security": [ 220 | { 221 | "api_key": [] 222 | } 223 | ] 224 | } 225 | }, 226 | "/apps/{app_id}/hard": { 227 | "delete": { 228 | "tags": [ 229 | "app" 230 | ], 231 | "summary": "Hard delete app", 232 | "description": "All app information will be removed from database", 233 | "produces": [ 234 | "application/json" 235 | ], 236 | "parameters": [ 237 | { 238 | "name": "app_id", 239 | "in": "path", 240 | "description": "name that need to be updated", 241 | "required": true, 242 | "type": "string" 243 | }, 244 | { 245 | "in": "body", 246 | "name": "body", 247 | "description": "Updated user object", 248 | "required": true, 249 | "schema": { 250 | "$ref": "#/definitions/CreateUser" 251 | } 252 | } 253 | ], 254 | "responses": { 255 | "200": { 256 | "description": "successful operation", 257 | "schema": { 258 | "$ref": "#/definitions/CreateUser" 259 | } 260 | }, 261 | "400": { 262 | "description": "Invalid Order" 263 | }, 264 | "401": { 265 | "description": "unauthorized", 266 | "schema": { 267 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 268 | } 269 | } 270 | }, 271 | "security": [ 272 | { 273 | "api_key": [] 274 | } 275 | ] 276 | } 277 | }, 278 | "/apps/{app_id}/restore": { 279 | "put": { 280 | "tags": [ 281 | "app" 282 | ], 283 | "summary": "Restores soft deleted app", 284 | "description": "All app information will be removed from database", 285 | "produces": [ 286 | "application/json" 287 | ], 288 | "parameters": [ 289 | { 290 | "name": "app_id", 291 | "in": "path", 292 | "description": "name that need to be updated", 293 | "required": true, 294 | "type": "string" 295 | }, 296 | { 297 | "in": "body", 298 | "name": "body", 299 | "description": "Updated user object", 300 | "required": true, 301 | "schema": { 302 | "$ref": "#/definitions/CreateUser" 303 | } 304 | } 305 | ], 306 | "responses": { 307 | "200": { 308 | "description": "successful operation", 309 | "schema": { 310 | "$ref": "#/definitions/CreateUser" 311 | } 312 | }, 313 | "400": { 314 | "description": "Invalid Order" 315 | }, 316 | "401": { 317 | "description": "unauthorized", 318 | "schema": { 319 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 320 | } 321 | } 322 | }, 323 | "security": [ 324 | { 325 | "api_key": [] 326 | } 327 | ] 328 | } 329 | }, 330 | "/users": { 331 | "post": { 332 | "tags": [ 333 | "user" 334 | ], 335 | "summary": "Create user", 336 | "description": "Creates user that can now be used for authentication", 337 | "operationId": "createUser", 338 | "produces": [ 339 | "application/json" 340 | ], 341 | "parameters": [ 342 | { 343 | "in": "body", 344 | "name": "body", 345 | "description": "Creates user", 346 | "required": true, 347 | "schema": { 348 | "$ref": "#/definitions/CreateUser" 349 | } 350 | } 351 | ], 352 | "responses": { 353 | "201": { 354 | "description": "successful operation", 355 | "schema": { 356 | "$ref": "#/definitions/CreateUserResponse" 357 | } 358 | }, 359 | "422": { 360 | "description": "Invalid operation", 361 | "schema": { 362 | "$ref": "#/definitions/ApiErrorResponse" 363 | } 364 | } 365 | } 366 | }, 367 | "get": { 368 | "tags": [ 369 | "user" 370 | ], 371 | "summary": "Return user", 372 | "description": "This can only be done by the logged in user.", 373 | "produces": [ 374 | "application/json" 375 | ], 376 | "responses": { 377 | "200": { 378 | "description": "successful operation", 379 | "schema": { 380 | "$ref": "#/definitions/ReturnUserResponse" 381 | } 382 | }, 383 | "401": { 384 | "description": "unauthorized", 385 | "schema": { 386 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 387 | } 388 | } 389 | }, 390 | "security": [ 391 | { 392 | "api_key": [] 393 | } 394 | ] 395 | }, 396 | "put": { 397 | "tags": [ 398 | "user" 399 | ], 400 | "summary": "Update user", 401 | "description": "This can only be done by the logged in user.", 402 | "parameters": [ 403 | { 404 | "in": "body", 405 | "name": "body", 406 | "description": "Creates user", 407 | "required": true, 408 | "schema": { 409 | "$ref": "#/definitions/UpdateUserBody" 410 | } 411 | } 412 | ], 413 | "produces": [ 414 | "application/json" 415 | ], 416 | "responses": { 417 | "200": { 418 | "description": "successful request", 419 | "schema": { 420 | "$ref": "#/definitions/ApiSuccessResponse" 421 | } 422 | }, 423 | "401": { 424 | "description": "unauthorized", 425 | "schema": { 426 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 427 | } 428 | } 429 | }, 430 | "security": [ 431 | { 432 | "api_key": [] 433 | } 434 | ] 435 | }, 436 | "delete": { 437 | "tags": [ 438 | "user" 439 | ], 440 | "summary": "Soft delete user", 441 | "description": "This can only be done by the logged in user.", 442 | "produces": [ 443 | "application/json" 444 | ], 445 | "responses": { 446 | "204": { 447 | "description": "success", 448 | "schema": { 449 | "$ref": "#/definitions/ApiSuccessResponse" 450 | } 451 | }, 452 | "401": { 453 | "description": "unauthorized", 454 | "schema": { 455 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 456 | } 457 | }, 458 | "default": { 459 | "description": "successful operation" 460 | } 461 | }, 462 | "security": [ 463 | { 464 | "api_key": [] 465 | } 466 | ] 467 | } 468 | }, 469 | "/users/hard": { 470 | "delete": { 471 | "tags": [ 472 | "user" 473 | ], 474 | "summary": "Hard delete user", 475 | "description": "Remove user from database", 476 | "produces": [ 477 | "application/json" 478 | ], 479 | "responses": { 480 | "204": { 481 | "description": "success", 482 | "schema": { 483 | "$ref": "#/definitions/ApiSuccessResponse" 484 | } 485 | }, 486 | "401": { 487 | "description": "unauthorized", 488 | "schema": { 489 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 490 | } 491 | }, 492 | "default": { 493 | "description": "successful operation" 494 | } 495 | }, 496 | "security": [ 497 | { 498 | "api_key": [] 499 | } 500 | ] 501 | } 502 | }, 503 | "/users/restore": { 504 | "put": { 505 | "tags": [ 506 | "user" 507 | ], 508 | "summary": "Restore soft deleted user", 509 | "description": "", 510 | "produces": [ 511 | "application/json" 512 | ], 513 | "responses": { 514 | "204": { 515 | "description": "success", 516 | "schema": { 517 | "$ref": "#/definitions/ApiSuccessResponse" 518 | } 519 | }, 520 | "401": { 521 | "description": "unauthorized", 522 | "schema": { 523 | "$ref": "#/definitions/ApiUnauthorizezdResponse" 524 | } 525 | }, 526 | "default": { 527 | "description": "successful operation" 528 | } 529 | }, 530 | "security": [ 531 | { 532 | "api_key": [] 533 | } 534 | ] 535 | } 536 | }, 537 | "/users/login": { 538 | "post": { 539 | "tags": [ 540 | "user" 541 | ], 542 | "summary": "User Login", 543 | "description": "Returns Bearer Token for JWT authentication", 544 | "operationId": "createUsersWithArrayInput", 545 | "produces": [ 546 | "application/json" 547 | ], 548 | "parameters": [ 549 | { 550 | "in": "body", 551 | "name": "body", 552 | "description": "List of user object", 553 | "required": true, 554 | "schema": { 555 | "type": "array", 556 | "items": { 557 | "$ref": "#/definitions/CreateUser" 558 | } 559 | } 560 | } 561 | ], 562 | "responses": { 563 | "204": { 564 | "description": "success", 565 | "schema": { 566 | "$ref": "#/definitions/LoginUserResponse" 567 | } 568 | }, 569 | "422": { 570 | "description": "error", 571 | "schema": { 572 | "$ref": "#/definitions/ApiErrorResponse" 573 | } 574 | } 575 | } 576 | } 577 | } 578 | }, 579 | "securityDefinitions": { 580 | "bearer_auth": { 581 | "type": "oauth2", 582 | "authorizationUrl": "http://api.your-url.io/v1/user/login", 583 | "flow": "implicit" 584 | }, 585 | "api_key": { 586 | "type": "apiKey", 587 | "name": "api_key", 588 | "in": "header" 589 | } 590 | }, 591 | "definitions": { 592 | "CreateUser": { 593 | "type": "object", 594 | "properties": { 595 | "unique_key | email | phone": { 596 | "type": "string", 597 | "example": "8885678345" 598 | }, 599 | "password": { 600 | "type": "string", 601 | "example": "secure-password" 602 | } 603 | } 604 | }, 605 | "CreateUserResponse": { 606 | "type": "object", 607 | "properties": { 608 | "success": { 609 | "type": "boolean", 610 | "example": true 611 | }, 612 | "message": { 613 | "type": "string", 614 | "example": "Successfully created new user." 615 | }, 616 | "token": { 617 | "type": "string", 618 | "example": "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ...", 619 | "description": "Authentication token" 620 | } 621 | } 622 | }, 623 | "LoginUserResponse": { 624 | "type": "object", 625 | "properties": { 626 | "success": { 627 | "type": "boolean", 628 | "example": true 629 | }, 630 | "token": { 631 | "type": "string", 632 | "example": "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ...", 633 | "description": "Authentication token" 634 | } 635 | } 636 | }, 637 | "ReturnUserResponse": { 638 | "type": "object", 639 | "properties": { 640 | "success": { 641 | "type": "boolean", 642 | "example": true 643 | }, 644 | "user": { 645 | "type": "object", 646 | "properties": { 647 | "first": { 648 | "type": "string", 649 | "example": "John" 650 | }, 651 | "last": { 652 | "type": "string", 653 | "example": "doe" 654 | }, 655 | "email": { 656 | "type": "string", 657 | "example": "john.doe@gmail.com" 658 | }, 659 | "phone": { 660 | "type": "string", 661 | "example": "8889401234" 662 | }, 663 | "apps": { 664 | "type": "array", 665 | "items": { 666 | "type": "object", 667 | "properties": { 668 | "_id": { 669 | "type": "string", 670 | "example": "12chd73nsjuf" 671 | }, 672 | "url": { 673 | "type": "string", 674 | "example": "www.orangetech.io" 675 | } 676 | } 677 | } 678 | } 679 | } 680 | } 681 | } 682 | }, 683 | "UpdateUserBody": { 684 | "type": "object", 685 | "properties": { 686 | "first": { 687 | "type": "string", 688 | "example": "John" 689 | }, 690 | "last": { 691 | "type": "string", 692 | "example": "doe" 693 | }, 694 | "email": { 695 | "type": "string", 696 | "example": "john.doe@gmail.com" 697 | }, 698 | "phone": { 699 | "type": "string", 700 | "example": "8889401234" 701 | } 702 | } 703 | }, 704 | "ApiErrorResponse": { 705 | "type": "object", 706 | "properties": { 707 | "success": { 708 | "type": "boolean", 709 | "example": false 710 | }, 711 | "error": { 712 | "type": "string" 713 | } 714 | } 715 | }, 716 | "ApiSuccessResponse": { 717 | "type": "object", 718 | "properties": { 719 | "success": { 720 | "type": "boolean", 721 | "example": true 722 | }, 723 | "message": { 724 | "type": "string" 725 | } 726 | } 727 | }, 728 | "ApiUnauthorizezdResponse": { 729 | "type": "string", 730 | "example": "Unauthorized" 731 | }, 732 | "ApiResponse": { 733 | "type": "object", 734 | "properties": { 735 | "code": { 736 | "type": "integer", 737 | "format": "int32" 738 | }, 739 | "type": { 740 | "type": "string" 741 | }, 742 | "message": { 743 | "type": "string" 744 | } 745 | } 746 | } 747 | }, 748 | "externalDocs": { 749 | "description": "Find out more about Orange Tech", 750 | "url": "http://orangetech.io" 751 | } 752 | } -------------------------------------------------------------------------------- /public/v1/documentation/dist/favicon-16x16.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/brianschardt/node_rest_api_mysql/87879ad9fab966a20ab266fe260551b42109c06c/public/v1/documentation/dist/favicon-16x16.png -------------------------------------------------------------------------------- /public/v1/documentation/dist/favicon-32x32.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/brianschardt/node_rest_api_mysql/87879ad9fab966a20ab266fe260551b42109c06c/public/v1/documentation/dist/favicon-32x32.png -------------------------------------------------------------------------------- /public/v1/documentation/dist/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | Swagger UI 7 | 8 | 9 | 10 | 11 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 |
69 | 70 | 71 | 72 | 93 | 94 | 95 | 96 | -------------------------------------------------------------------------------- /public/v1/documentation/dist/oauth2-redirect.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 61 | -------------------------------------------------------------------------------- /public/v1/documentation/dist/swagger-ui.css: -------------------------------------------------------------------------------- 1 | .swagger-ui{font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .wrapper{width:100%;max-width:1460px;margin:0 auto;padding:0 20px}.swagger-ui .opblock-tag-section{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.swagger-ui .opblock-tag{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:10px 20px 10px 10px;cursor:pointer;-webkit-transition:all .2s;transition:all .2s;border-bottom:1px solid rgba(59,65,81,.3)}.swagger-ui .opblock-tag:hover{background:rgba(0,0,0,.02)}.swagger-ui .opblock-tag{font-size:24px;margin:0 0 5px;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .opblock-tag.no-desc span{-webkit-box-flex:1;-ms-flex:1;flex:1}.swagger-ui .opblock-tag svg{-webkit-transition:all .4s;transition:all .4s}.swagger-ui .opblock-tag small{font-size:14px;font-weight:400;-webkit-box-flex:1;-ms-flex:1;flex:1;padding:0 10px;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .parameter__type{font-size:12px;padding:5px 0;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui .view-line-link{position:relative;top:3px;width:20px;margin:0 5px;cursor:pointer;-webkit-transition:all .5s;transition:all .5s}.swagger-ui .opblock{margin:0 0 15px;border:1px solid #000;border-radius:4px;-webkit-box-shadow:0 0 3px rgba(0,0,0,.19);box-shadow:0 0 3px rgba(0,0,0,.19)}.swagger-ui .opblock .tab-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1;flex:1}.swagger-ui .opblock .tab-header .tab-item{padding:0 40px;cursor:pointer}.swagger-ui .opblock .tab-header .tab-item:first-of-type{padding:0 40px 0 0}.swagger-ui .opblock .tab-header .tab-item.active h4 span{position:relative}.swagger-ui .opblock .tab-header .tab-item.active h4 span:after{position:absolute;bottom:-15px;left:50%;width:120%;height:4px;content:"";-webkit-transform:translateX(-50%);transform:translateX(-50%);background:gray}.swagger-ui .opblock.is-open .opblock-summary{border-bottom:1px solid #000}.swagger-ui .opblock .opblock-section-header{padding:8px 20px;min-height:50px;background:hsla(0,0%,100%,.8);-webkit-box-shadow:0 1px 2px rgba(0,0,0,.1);box-shadow:0 1px 2px rgba(0,0,0,.1)}.swagger-ui .opblock .opblock-section-header,.swagger-ui .opblock .opblock-section-header label{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.swagger-ui .opblock .opblock-section-header label{font-size:12px;font-weight:700;margin:0;margin-left:auto;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .opblock .opblock-section-header label span{padding:0 10px 0 0}.swagger-ui .opblock .opblock-section-header h4{font-size:14px;-webkit-box-flex:1;-ms-flex:1;flex:1;margin:0;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .opblock .opblock-summary-method{font-size:14px;font-weight:700;min-width:80px;padding:6px 15px;text-align:center;border-radius:3px;background:#000;text-shadow:0 1px 0 rgba(0,0,0,.1);font-family:Titillium Web,sans-serif;color:#fff}.swagger-ui .opblock .opblock-summary-operation-id,.swagger-ui .opblock .opblock-summary-path,.swagger-ui .opblock .opblock-summary-path__deprecated{font-size:16px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 3 auto;flex:0 3 auto;-webkit-box-align:center;-ms-flex-align:center;align-items:center;word-break:break-all;padding:0 10px;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}@media (max-width:768px){.swagger-ui .opblock .opblock-summary-operation-id,.swagger-ui .opblock .opblock-summary-path,.swagger-ui .opblock .opblock-summary-path__deprecated{font-size:12px}}.swagger-ui .opblock .opblock-summary-operation-id .view-line-link,.swagger-ui .opblock .opblock-summary-path .view-line-link,.swagger-ui .opblock .opblock-summary-path__deprecated .view-line-link{position:relative;top:2px;width:0;margin:0;cursor:pointer;-webkit-transition:all .5s;transition:all .5s}.swagger-ui .opblock .opblock-summary-operation-id:hover .view-line-link,.swagger-ui .opblock .opblock-summary-path:hover .view-line-link,.swagger-ui .opblock .opblock-summary-path__deprecated:hover .view-line-link{width:18px;margin:0 5px}.swagger-ui .opblock .opblock-summary-path__deprecated{text-decoration:line-through}.swagger-ui .opblock .opblock-summary-operation-id{font-size:14px}.swagger-ui .opblock .opblock-summary-description{font-size:13px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .opblock .opblock-summary{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:5px;cursor:pointer}.swagger-ui .opblock.opblock-post{border-color:#49cc90;background:rgba(73,204,144,.1)}.swagger-ui .opblock.opblock-post .opblock-summary-method{background:#49cc90}.swagger-ui .opblock.opblock-post .opblock-summary{border-color:#49cc90}.swagger-ui .opblock.opblock-post .tab-header .tab-item.active h4 span:after{background:#49cc90}.swagger-ui .opblock.opblock-put{border-color:#fca130;background:rgba(252,161,48,.1)}.swagger-ui .opblock.opblock-put .opblock-summary-method{background:#fca130}.swagger-ui .opblock.opblock-put .opblock-summary{border-color:#fca130}.swagger-ui .opblock.opblock-put .tab-header .tab-item.active h4 span:after{background:#fca130}.swagger-ui .opblock.opblock-delete{border-color:#f93e3e;background:rgba(249,62,62,.1)}.swagger-ui .opblock.opblock-delete .opblock-summary-method{background:#f93e3e}.swagger-ui .opblock.opblock-delete .opblock-summary{border-color:#f93e3e}.swagger-ui .opblock.opblock-delete .tab-header .tab-item.active h4 span:after{background:#f93e3e}.swagger-ui .opblock.opblock-get{border-color:#61affe;background:rgba(97,175,254,.1)}.swagger-ui .opblock.opblock-get .opblock-summary-method{background:#61affe}.swagger-ui .opblock.opblock-get .opblock-summary{border-color:#61affe}.swagger-ui .opblock.opblock-get .tab-header .tab-item.active h4 span:after{background:#61affe}.swagger-ui .opblock.opblock-patch{border-color:#50e3c2;background:rgba(80,227,194,.1)}.swagger-ui .opblock.opblock-patch .opblock-summary-method{background:#50e3c2}.swagger-ui .opblock.opblock-patch .opblock-summary{border-color:#50e3c2}.swagger-ui .opblock.opblock-patch .tab-header .tab-item.active h4 span:after{background:#50e3c2}.swagger-ui .opblock.opblock-head{border-color:#9012fe;background:rgba(144,18,254,.1)}.swagger-ui .opblock.opblock-head .opblock-summary-method{background:#9012fe}.swagger-ui .opblock.opblock-head .opblock-summary{border-color:#9012fe}.swagger-ui .opblock.opblock-head .tab-header .tab-item.active h4 span:after{background:#9012fe}.swagger-ui .opblock.opblock-options{border-color:#0d5aa7;background:rgba(13,90,167,.1)}.swagger-ui .opblock.opblock-options .opblock-summary-method{background:#0d5aa7}.swagger-ui .opblock.opblock-options .opblock-summary{border-color:#0d5aa7}.swagger-ui .opblock.opblock-options .tab-header .tab-item.active h4 span:after{background:#0d5aa7}.swagger-ui .opblock.opblock-deprecated{opacity:.6;border-color:#ebebeb;background:hsla(0,0%,92%,.1)}.swagger-ui .opblock.opblock-deprecated .opblock-summary-method{background:#ebebeb}.swagger-ui .opblock.opblock-deprecated .opblock-summary{border-color:#ebebeb}.swagger-ui .opblock.opblock-deprecated .tab-header .tab-item.active h4 span:after{background:#ebebeb}.swagger-ui .opblock .opblock-schemes{padding:8px 20px}.swagger-ui .opblock .opblock-schemes .schemes-title{padding:0 10px 0 0}.swagger-ui .filter .operation-filter-input{width:100%;margin:20px 0;padding:10px;border:2px solid #d8dde7}.swagger-ui .tab{display:-webkit-box;display:-ms-flexbox;display:flex;margin:20px 0 10px;padding:0;list-style:none}.swagger-ui .tab li{font-size:12px;min-width:100px;min-width:90px;padding:0;cursor:pointer;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .tab li:first-of-type{position:relative;padding-left:0}.swagger-ui .tab li:first-of-type:after{position:absolute;top:0;right:6px;width:1px;height:100%;content:"";background:rgba(0,0,0,.2)}.swagger-ui .tab li.active{font-weight:700}.swagger-ui .opblock-description-wrapper,.swagger-ui .opblock-external-docs-wrapper,.swagger-ui .opblock-title_normal{font-size:12px;margin:0 0 5px;padding:15px 20px;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .opblock-description-wrapper h4,.swagger-ui .opblock-external-docs-wrapper h4,.swagger-ui .opblock-title_normal h4{font-size:12px;margin:0 0 5px;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .opblock-description-wrapper p,.swagger-ui .opblock-external-docs-wrapper p,.swagger-ui .opblock-title_normal p{font-size:14px;margin:0;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .opblock-external-docs-wrapper h4{padding-left:0}.swagger-ui .execute-wrapper{padding:20px;text-align:right}.swagger-ui .execute-wrapper .btn{width:100%;padding:8px 40px}.swagger-ui .body-param-options{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.swagger-ui .body-param-options .body-param-edit{padding:10px 0}.swagger-ui .body-param-options label{padding:8px 0}.swagger-ui .body-param-options label select{margin:3px 0 0}.swagger-ui .responses-inner{padding:20px}.swagger-ui .responses-inner h4,.swagger-ui .responses-inner h5{font-size:12px;margin:10px 0 5px;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .response-col_status{font-size:14px;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .response-col_status .response-undocumented{font-size:11px;font-family:Source Code Pro,monospace;font-weight:600;color:#909090}.swagger-ui .response-col_links{padding-left:2em;max-width:40em;font-size:14px;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .response-col_links .response-undocumented{font-size:11px;font-family:Source Code Pro,monospace;font-weight:600;color:#909090}.swagger-ui .response-col_description__inner div.markdown,.swagger-ui .response-col_description__inner div.renderedMarkdown{font-size:12px;font-style:italic;display:block;margin:0;padding:10px;border-radius:4px;background:#41444e;font-family:Source Code Pro,monospace;font-weight:600;color:#fff}.swagger-ui .response-col_description__inner div.markdown p,.swagger-ui .response-col_description__inner div.renderedMarkdown p{margin:0;font-family:Source Code Pro,monospace;font-weight:600;color:#fff}.swagger-ui .response-col_description__inner div.markdown a,.swagger-ui .response-col_description__inner div.renderedMarkdown a{font-family:Source Code Pro,monospace;font-weight:600;color:#89bf04;text-decoration:underline}.swagger-ui .response-col_description__inner div.markdown a:hover,.swagger-ui .response-col_description__inner div.renderedMarkdown a:hover{color:#81b10c}.swagger-ui .response-col_description__inner div.markdown th,.swagger-ui .response-col_description__inner div.renderedMarkdown th{font-family:Source Code Pro,monospace;font-weight:600;color:#fff;border-bottom:1px solid #fff}.swagger-ui .opblock-body pre{font-size:12px;margin:0;padding:10px;white-space:pre-wrap;word-wrap:break-word;word-break:break-all;word-break:break-word;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;border-radius:4px;background:#41444e;overflow-wrap:break-word;font-family:Source Code Pro,monospace;font-weight:600;color:#fff}.swagger-ui .opblock-body pre span{color:#fff!important}.swagger-ui .opblock-body pre .headerline{display:block}.swagger-ui .scheme-container{margin:0 0 20px;padding:30px 0;background:#fff;-webkit-box-shadow:0 1px 2px 0 rgba(0,0,0,.15);box-shadow:0 1px 2px 0 rgba(0,0,0,.15)}.swagger-ui .scheme-container .schemes{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.swagger-ui .scheme-container .schemes>label{font-size:12px;font-weight:700;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;margin:-20px 15px 0 0;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .scheme-container .schemes>label select{min-width:130px;text-transform:uppercase}.swagger-ui .loading-container{padding:40px 0 60px;margin-top:1em;min-height:1px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.swagger-ui .loading-container .loading{position:relative}.swagger-ui .loading-container .loading:after{font-size:10px;font-weight:700;position:absolute;top:50%;left:50%;content:"loading";-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);text-transform:uppercase;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .loading-container .loading:before{position:absolute;top:50%;left:50%;display:block;width:60px;height:60px;margin:-30px;content:"";-webkit-animation:rotation 1s infinite linear,opacity .5s;animation:rotation 1s infinite linear,opacity .5s;opacity:1;border:2px solid rgba(85,85,85,.1);border-top-color:rgba(0,0,0,.6);border-radius:100%;-webkit-backface-visibility:hidden;backface-visibility:hidden}@-webkit-keyframes rotation{to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes rotation{to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.swagger-ui .response-content-type{padding-top:1em}.swagger-ui .response-content-type.controls-accept-header select{border-color:green}.swagger-ui .response-content-type.controls-accept-header small{color:green;font-size:.7em}@-webkit-keyframes blinker{50%{opacity:0}}@keyframes blinker{50%{opacity:0}}.swagger-ui section h3{font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui a.nostyle{display:inline}.swagger-ui a.nostyle,.swagger-ui a.nostyle:visited{text-decoration:inherit;color:inherit;cursor:pointer}.swagger-ui .btn{font-size:14px;font-weight:700;padding:5px 23px;-webkit-transition:all .3s;transition:all .3s;border:2px solid gray;border-radius:4px;background:transparent;-webkit-box-shadow:0 1px 2px rgba(0,0,0,.1);box-shadow:0 1px 2px rgba(0,0,0,.1);font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .btn.btn-sm{font-size:12px;padding:4px 23px}.swagger-ui .btn[disabled]{cursor:not-allowed;opacity:.3}.swagger-ui .btn:hover{-webkit-box-shadow:0 0 5px rgba(0,0,0,.3);box-shadow:0 0 5px rgba(0,0,0,.3)}.swagger-ui .btn.cancel{border-color:#ff6060;background-color:transparent;font-family:Titillium Web,sans-serif;color:#ff6060}.swagger-ui .btn.authorize{line-height:1;display:inline;color:#49cc90;border-color:#49cc90;background-color:transparent}.swagger-ui .btn.authorize span{float:left;padding:4px 20px 0 0}.swagger-ui .btn.authorize svg{fill:#49cc90}.swagger-ui .btn.execute{-webkit-animation:swagger-ui-pulse 2s infinite;animation:swagger-ui-pulse 2s infinite;will-change:transform;background-color:transparent;color:#fff;border-color:#4990e2}@-webkit-keyframes swagger-ui-pulse{0%{color:#fff;background:#4990e2;-webkit-box-shadow:0 0 0 0 rgba(73,144,226,.8);box-shadow:0 0 0 0 rgba(73,144,226,.8)}70%{-webkit-box-shadow:0 0 0 5px rgba(73,144,226,0);box-shadow:0 0 0 5px rgba(73,144,226,0)}to{color:#fff;background:#4990e2;-webkit-box-shadow:0 0 0 0 rgba(73,144,226,0);box-shadow:0 0 0 0 rgba(73,144,226,0)}}@keyframes swagger-ui-pulse{0%{color:#fff;background:#4990e2;-webkit-box-shadow:0 0 0 0 rgba(73,144,226,.8);box-shadow:0 0 0 0 rgba(73,144,226,.8)}70%{-webkit-box-shadow:0 0 0 5px rgba(73,144,226,0);box-shadow:0 0 0 5px rgba(73,144,226,0)}to{color:#fff;background:#4990e2;-webkit-box-shadow:0 0 0 0 rgba(73,144,226,0);box-shadow:0 0 0 0 rgba(73,144,226,0)}}.swagger-ui .btn-group{display:-webkit-box;display:-ms-flexbox;display:flex;padding:30px}.swagger-ui .btn-group .btn{-webkit-box-flex:1;-ms-flex:1;flex:1}.swagger-ui .btn-group .btn:first-child{border-radius:4px 0 0 4px}.swagger-ui .btn-group .btn:last-child{border-radius:0 4px 4px 0}.swagger-ui .authorization__btn{padding:0 10px;border:none;background:none}.swagger-ui .authorization__btn.locked{opacity:1}.swagger-ui .authorization__btn.unlocked{opacity:.4}.swagger-ui .expand-methods,.swagger-ui .expand-operation{border:none;background:none}.swagger-ui .expand-methods svg,.swagger-ui .expand-operation svg{width:20px;height:20px}.swagger-ui .expand-methods{padding:0 10px}.swagger-ui .expand-methods:hover svg{fill:#404040}.swagger-ui .expand-methods svg{-webkit-transition:all .3s;transition:all .3s;fill:#707070}.swagger-ui button{cursor:pointer;outline:none}.swagger-ui button.invalid{-webkit-animation:shake .4s 1;animation:shake .4s 1;border-color:#f93e3e;background:#feebeb}.swagger-ui select{font-size:14px;font-weight:700;padding:5px 40px 5px 10px;border:2px solid #41444e;border-radius:4px;background:#f7f7f7 url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyMCAyMCI+ICAgIDxwYXRoIGQ9Ik0xMy40MTggNy44NTljLjI3MS0uMjY4LjcwOS0uMjY4Ljk3OCAwIC4yNy4yNjguMjcyLjcwMSAwIC45NjlsLTMuOTA4IDMuODNjLS4yNy4yNjgtLjcwNy4yNjgtLjk3OSAwbC0zLjkwOC0zLjgzYy0uMjctLjI2Ny0uMjctLjcwMSAwLS45NjkuMjcxLS4yNjguNzA5LS4yNjguOTc4IDBMMTAgMTFsMy40MTgtMy4xNDF6Ii8+PC9zdmc+) right 10px center no-repeat;background-size:20px;-webkit-box-shadow:0 1px 2px 0 rgba(0,0,0,.25);box-shadow:0 1px 2px 0 rgba(0,0,0,.25);font-family:Titillium Web,sans-serif;color:#3b4151;-webkit-appearance:none;-moz-appearance:none;appearance:none}.swagger-ui select[multiple]{margin:5px 0;padding:5px;background:#f7f7f7}.swagger-ui select.invalid{-webkit-animation:shake .4s 1;animation:shake .4s 1;border-color:#f93e3e;background:#feebeb}.swagger-ui .opblock-body select{min-width:230px}@media (max-width:768px){.swagger-ui .opblock-body select{min-width:180px}}.swagger-ui label{font-size:12px;font-weight:700;margin:0 0 5px;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui input[type=email],.swagger-ui input[type=file],.swagger-ui input[type=password],.swagger-ui input[type=search],.swagger-ui input[type=text]{min-width:100px;margin:5px 0;padding:8px 10px;border:1px solid #d9d9d9;border-radius:4px;background:#fff}@media (max-width:768px){.swagger-ui input[type=email],.swagger-ui input[type=file],.swagger-ui input[type=password],.swagger-ui input[type=search],.swagger-ui input[type=text]{max-width:175px}}.swagger-ui input[type=email].invalid,.swagger-ui input[type=file].invalid,.swagger-ui input[type=password].invalid,.swagger-ui input[type=search].invalid,.swagger-ui input[type=text].invalid{-webkit-animation:shake .4s 1;animation:shake .4s 1;border-color:#f93e3e;background:#feebeb}@-webkit-keyframes shake{10%,90%{-webkit-transform:translate3d(-1px,0,0);transform:translate3d(-1px,0,0)}20%,80%{-webkit-transform:translate3d(2px,0,0);transform:translate3d(2px,0,0)}30%,50%,70%{-webkit-transform:translate3d(-4px,0,0);transform:translate3d(-4px,0,0)}40%,60%{-webkit-transform:translate3d(4px,0,0);transform:translate3d(4px,0,0)}}@keyframes shake{10%,90%{-webkit-transform:translate3d(-1px,0,0);transform:translate3d(-1px,0,0)}20%,80%{-webkit-transform:translate3d(2px,0,0);transform:translate3d(2px,0,0)}30%,50%,70%{-webkit-transform:translate3d(-4px,0,0);transform:translate3d(-4px,0,0)}40%,60%{-webkit-transform:translate3d(4px,0,0);transform:translate3d(4px,0,0)}}.swagger-ui textarea{font-size:12px;width:100%;min-height:280px;padding:10px;border:none;border-radius:4px;outline:none;background:hsla(0,0%,100%,.8);font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui textarea:focus{border:2px solid #61affe}.swagger-ui textarea.curl{font-size:12px;min-height:100px;margin:0;padding:10px;resize:none;border-radius:4px;background:#41444e;font-family:Source Code Pro,monospace;font-weight:600;color:#fff}.swagger-ui .checkbox{padding:5px 0 10px;-webkit-transition:opacity .5s;transition:opacity .5s;color:#303030}.swagger-ui .checkbox label{display:-webkit-box;display:-ms-flexbox;display:flex}.swagger-ui .checkbox p{font-weight:400!important;font-style:italic;margin:0!important;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui .checkbox input[type=checkbox]{display:none}.swagger-ui .checkbox input[type=checkbox]+label>.item{position:relative;top:3px;display:inline-block;width:16px;height:16px;margin:0 8px 0 0;padding:5px;cursor:pointer;border-radius:1px;background:#e8e8e8;-webkit-box-shadow:0 0 0 2px #e8e8e8;box-shadow:0 0 0 2px #e8e8e8;-webkit-box-flex:0;-ms-flex:none;flex:none}.swagger-ui .checkbox input[type=checkbox]+label>.item:active{-webkit-transform:scale(.9);transform:scale(.9)}.swagger-ui .checkbox input[type=checkbox]:checked+label>.item{background:#e8e8e8 url("data:image/svg+xml;charset=utf-8,%3Csvg width='10' height='8' viewBox='3 7 10 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%2341474E' fill-rule='evenodd' d='M6.333 15L3 11.667l1.333-1.334 2 2L11.667 7 13 8.333z'/%3E%3C/svg%3E") 50% no-repeat}.swagger-ui .dialog-ux{position:fixed;z-index:9999;top:0;right:0;bottom:0;left:0}.swagger-ui .dialog-ux .backdrop-ux{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.8)}.swagger-ui .dialog-ux .modal-ux{position:absolute;z-index:9999;top:50%;left:50%;width:100%;min-width:300px;max-width:650px;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);border:1px solid #ebebeb;border-radius:4px;background:#fff;-webkit-box-shadow:0 10px 30px 0 rgba(0,0,0,.2);box-shadow:0 10px 30px 0 rgba(0,0,0,.2)}.swagger-ui .dialog-ux .modal-ux-content{overflow-y:auto;max-height:540px;padding:20px}.swagger-ui .dialog-ux .modal-ux-content p{font-size:12px;margin:0 0 5px;color:#41444e;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .dialog-ux .modal-ux-content h4{font-size:18px;font-weight:600;margin:15px 0 0;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .dialog-ux .modal-ux-header{display:-webkit-box;display:-ms-flexbox;display:flex;padding:12px 0;border-bottom:1px solid #ebebeb;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.swagger-ui .dialog-ux .modal-ux-header .close-modal{padding:0 10px;border:none;background:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.swagger-ui .dialog-ux .modal-ux-header h3{font-size:20px;font-weight:600;margin:0;padding:0 20px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .model{font-size:12px;font-weight:300;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui .model .deprecated span,.swagger-ui .model .deprecated td{color:#a0a0a0!important}.swagger-ui .model .deprecated>td:first-of-type{text-decoration:line-through}.swagger-ui .model-toggle{font-size:10px;position:relative;top:6px;display:inline-block;margin:auto .3em;cursor:pointer;-webkit-transition:-webkit-transform .15s ease-in;transition:-webkit-transform .15s ease-in;transition:transform .15s ease-in;transition:transform .15s ease-in,-webkit-transform .15s ease-in;-webkit-transform:rotate(90deg);transform:rotate(90deg);-webkit-transform-origin:50% 50%;transform-origin:50% 50%}.swagger-ui .model-toggle.collapsed{-webkit-transform:rotate(0deg);transform:rotate(0deg)}.swagger-ui .model-toggle:after{display:block;width:20px;height:20px;content:"";background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath d='M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z'/%3E%3C/svg%3E") 50% no-repeat;background-size:100%}.swagger-ui .model-jump-to-path{position:relative;cursor:pointer}.swagger-ui .model-jump-to-path .view-line-link{position:absolute;top:-.4em;cursor:pointer}.swagger-ui .model-title{position:relative}.swagger-ui .model-title:hover .model-hint{visibility:visible}.swagger-ui .model-hint{position:absolute;top:-1.8em;visibility:hidden;padding:.1em .5em;white-space:nowrap;color:#ebebeb;border-radius:4px;background:rgba(0,0,0,.7)}.swagger-ui .model p{margin:0 0 1em}.swagger-ui section.models{margin:30px 0;border:1px solid rgba(59,65,81,.3);border-radius:4px}.swagger-ui section.models.is-open{padding:0 0 20px}.swagger-ui section.models.is-open h4{margin:0 0 5px;border-bottom:1px solid rgba(59,65,81,.3)}.swagger-ui section.models h4{font-size:16px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin:0;padding:10px 20px 10px 10px;cursor:pointer;-webkit-transition:all .2s;transition:all .2s;font-family:Titillium Web,sans-serif;color:#707070}.swagger-ui section.models h4 svg{-webkit-transition:all .4s;transition:all .4s}.swagger-ui section.models h4 span{-webkit-box-flex:1;-ms-flex:1;flex:1}.swagger-ui section.models h4:hover{background:rgba(0,0,0,.02)}.swagger-ui section.models h5{font-size:16px;margin:0 0 10px;font-family:Titillium Web,sans-serif;color:#707070}.swagger-ui section.models .model-jump-to-path{position:relative;top:5px}.swagger-ui section.models .model-container{margin:0 20px 15px;-webkit-transition:all .5s;transition:all .5s;border-radius:4px;background:rgba(0,0,0,.05)}.swagger-ui section.models .model-container:hover{background:rgba(0,0,0,.07)}.swagger-ui section.models .model-container:first-of-type{margin:20px}.swagger-ui section.models .model-container:last-of-type{margin:0 20px}.swagger-ui section.models .model-box{background:none}.swagger-ui .model-box{padding:10px;border-radius:4px;background:rgba(0,0,0,.1)}.swagger-ui .model-box .model-jump-to-path{position:relative;top:4px}.swagger-ui .model-box.deprecated{opacity:.5}.swagger-ui .model-title{font-size:16px;font-family:Titillium Web,sans-serif;color:#505050}.swagger-ui .model-deprecated-warning{font-size:16px;font-weight:600;margin-right:1em;font-family:Titillium Web,sans-serif;color:#f93e3e}.swagger-ui span>span.model .brace-close{padding:0 0 0 10px}.swagger-ui .prop-name{display:inline-block;margin-right:1em}.swagger-ui .prop-type{color:#55a}.swagger-ui .prop-enum{display:block}.swagger-ui .prop-format{color:#909090}.swagger-ui .servers>label{font-size:12px;margin:-20px 15px 0 0;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .servers>label select{min-width:130px;max-width:100%}.swagger-ui .servers h4.message{padding-bottom:2em}.swagger-ui .servers table tr{width:30em}.swagger-ui .servers table td{display:inline-block;max-width:15em;vertical-align:middle;padding-top:10px;padding-bottom:10px}.swagger-ui .servers table td:first-of-type{padding-right:2em}.swagger-ui .servers table td input{width:100%;height:100%}.swagger-ui .servers .computed-url{margin:2em 0}.swagger-ui .servers .computed-url code{display:inline-block;padding:4px;font-size:16px;margin:0 1em}.swagger-ui .global-server-container{margin:0 0 20px;padding:30px 0;background:#fff;-webkit-box-shadow:0 1px 2px 0 rgba(0,0,0,.15);box-shadow:0 1px 2px 0 rgba(0,0,0,.15)}.swagger-ui .global-server-container .servers-title{line-height:2em;font-weight:700}.swagger-ui .operation-servers h4.message{margin-bottom:2em}.swagger-ui table{width:100%;padding:0 10px;border-collapse:collapse}.swagger-ui table.model tbody tr td{padding:0;vertical-align:top}.swagger-ui table.model tbody tr td:first-of-type{width:174px;padding:0 0 0 2em}.swagger-ui table.headers td{font-size:12px;font-weight:300;vertical-align:middle;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui table tbody tr td{padding:10px 0 0;vertical-align:top}.swagger-ui table tbody tr td:first-of-type{max-width:20%;min-width:6em;padding:10px 0}.swagger-ui table thead tr td,.swagger-ui table thead tr th{font-size:12px;font-weight:700;padding:12px 0;text-align:left;border-bottom:1px solid rgba(59,65,81,.2);font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .parameters-col_description p{font-size:14px;margin:0;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .parameters-col_description input[type=text]{width:100%;max-width:340px}.swagger-ui .parameters-col_description select{border-width:1px}.swagger-ui .parameter__name{font-size:16px;font-weight:400;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .parameter__name.required{font-weight:700}.swagger-ui .parameter__name.required:after{font-size:10px;position:relative;top:-6px;padding:5px;content:"required";color:rgba(255,0,0,.6)}.swagger-ui .parameter__extension,.swagger-ui .parameter__in{font-size:12px;font-style:italic;font-family:Source Code Pro,monospace;font-weight:600;color:gray}.swagger-ui .parameter__deprecated{font-size:12px;font-style:italic;font-family:Source Code Pro,monospace;font-weight:600;color:red}.swagger-ui .table-container{padding:20px}.swagger-ui .topbar{padding:8px 0;background-color:#89bf04}.swagger-ui .topbar .topbar-wrapper,.swagger-ui .topbar a{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.swagger-ui .topbar a{font-size:1.5em;font-weight:700;-webkit-box-flex:1;-ms-flex:1;flex:1;max-width:300px;text-decoration:none;font-family:Titillium Web,sans-serif;color:#fff}.swagger-ui .topbar a span{margin:0;padding:0 10px}.swagger-ui .topbar .download-url-wrapper{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:3;-ms-flex:3;flex:3;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}.swagger-ui .topbar .download-url-wrapper input[type=text]{width:100%;margin:0;border:2px solid #547f00;border-radius:4px 0 0 4px;outline:none}.swagger-ui .topbar .download-url-wrapper .select-label{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;width:100%;max-width:600px;margin:0}.swagger-ui .topbar .download-url-wrapper .select-label span{font-size:16px;-webkit-box-flex:1;-ms-flex:1;flex:1;padding:0 10px 0 0;text-align:right}.swagger-ui .topbar .download-url-wrapper .select-label select{-webkit-box-flex:2;-ms-flex:2;flex:2;width:100%;border:2px solid #547f00;outline:none;-webkit-box-shadow:none;box-shadow:none}.swagger-ui .topbar .download-url-wrapper .download-url-button{font-size:16px;font-weight:700;padding:4px 30px;border:none;border-radius:0 4px 4px 0;background:#547f00;font-family:Titillium Web,sans-serif;color:#fff}.swagger-ui .info{margin:50px 0}.swagger-ui .info hgroup.main{margin:0 0 20px}.swagger-ui .info hgroup.main a{font-size:12px}.swagger-ui .info li,.swagger-ui .info p,.swagger-ui .info table{font-size:14px;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .info h1,.swagger-ui .info h2,.swagger-ui .info h3,.swagger-ui .info h4,.swagger-ui .info h5{font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .info code{padding:3px 5px;border-radius:4px;background:rgba(0,0,0,.05);font-family:Source Code Pro,monospace;font-weight:600;color:#9012fe}.swagger-ui .info a{font-size:14px;-webkit-transition:all .4s;transition:all .4s;font-family:Open Sans,sans-serif;color:#4990e2}.swagger-ui .info a:hover{color:#1f69c0}.swagger-ui .info>div{margin:0 0 5px}.swagger-ui .info .base-url{font-size:12px;font-weight:300!important;margin:0;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui .info .title{font-size:36px;margin:0;font-family:Open Sans,sans-serif;color:#3b4151}.swagger-ui .info .title small{font-size:10px;position:relative;top:-5px;display:inline-block;margin:0 0 0 5px;padding:2px 4px;vertical-align:super;border-radius:57px;background:#7d8492}.swagger-ui .info .title small pre{margin:0;font-family:Titillium Web,sans-serif;color:#fff}.swagger-ui .auth-btn-wrapper{display:-webkit-box;display:-ms-flexbox;display:flex;padding:10px 0;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.swagger-ui .auth-btn-wrapper .btn-done{margin-right:1em}.swagger-ui .auth-wrapper{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1;flex:1;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}.swagger-ui .auth-wrapper .authorize{padding-right:20px}.swagger-ui .auth-container{margin:0 0 10px;padding:10px 20px;border-bottom:1px solid #ebebeb}.swagger-ui .auth-container:last-of-type{margin:0;padding:10px 20px;border:0}.swagger-ui .auth-container h4{margin:5px 0 15px!important}.swagger-ui .auth-container .wrapper{margin:0;padding:0}.swagger-ui .auth-container input[type=password],.swagger-ui .auth-container input[type=text]{min-width:230px}.swagger-ui .auth-container .errors{font-size:12px;padding:10px;border-radius:4px;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui .scopes h2{font-size:14px;font-family:Titillium Web,sans-serif;color:#3b4151}.swagger-ui .scope-def{padding:0 0 20px}.swagger-ui .errors-wrapper{margin:20px;padding:10px 20px;-webkit-animation:scaleUp .5s;animation:scaleUp .5s;border:2px solid #f93e3e;border-radius:4px;background:rgba(249,62,62,.1)}.swagger-ui .errors-wrapper .error-wrapper{margin:0 0 10px}.swagger-ui .errors-wrapper .errors h4{font-size:14px;margin:0;font-family:Source Code Pro,monospace;font-weight:600;color:#3b4151}.swagger-ui .errors-wrapper .errors small{color:#606060}.swagger-ui .errors-wrapper hgroup{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.swagger-ui .errors-wrapper hgroup h4{font-size:20px;margin:0;-webkit-box-flex:1;-ms-flex:1;flex:1;font-family:Titillium Web,sans-serif;color:#3b4151}@-webkit-keyframes scaleUp{0%{-webkit-transform:scale(.8);transform:scale(.8);opacity:0}to{-webkit-transform:scale(1);transform:scale(1);opacity:1}}@keyframes scaleUp{0%{-webkit-transform:scale(.8);transform:scale(.8);opacity:0}to{-webkit-transform:scale(1);transform:scale(1);opacity:1}}.swagger-ui .Resizer.vertical.disabled{display:none} 2 | /*# sourceMappingURL=swagger-ui.css.map*/ -------------------------------------------------------------------------------- /public/v1/documentation/dist/swagger-ui.css.map: -------------------------------------------------------------------------------- 1 | {"version":3,"sources":[],"names":[],"mappings":"","file":"swagger-ui.css","sourceRoot":""} -------------------------------------------------------------------------------- /routes/v1.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const router = express.Router(); 3 | 4 | const UserController = require('../controllers/user.controller'); 5 | const CompanyController = require('../controllers/company.controller'); 6 | const HomeController = require('../controllers/home.controller'); 7 | 8 | const custom = require('./../middleware/custom'); 9 | 10 | const passport = require('passport'); 11 | const path = require('path'); 12 | 13 | 14 | require('./../middleware/passport')(passport) 15 | /* GET home page. */ 16 | router.get('/', function(req, res, next) { 17 | res.json({status:"success", message:"Parcel Pending API", data:{"version_number":"v1.0.0"}}) 18 | }); 19 | 20 | 21 | router.post( '/users', UserController.create); // C 22 | router.get( '/users', passport.authenticate('jwt', {session:false}), UserController.get); // R 23 | router.put( '/users', passport.authenticate('jwt', {session:false}), UserController.update); // U 24 | router.delete( '/users', passport.authenticate('jwt', {session:false}), UserController.remove); // D 25 | router.post( '/users/login', UserController.login); 26 | 27 | router.post( '/companies', passport.authenticate('jwt', {session:false}), CompanyController.create); // C 28 | router.get( '/companies', passport.authenticate('jwt', {session:false}), CompanyController.getAll); // R 29 | 30 | router.get( '/companies/:company_id', passport.authenticate('jwt', {session:false}), custom.company, CompanyController.get); // R 31 | router.put( '/companies/:company_id', passport.authenticate('jwt', {session:false}), custom.company, CompanyController.update); // U 32 | router.delete( '/companies/:company_id', passport.authenticate('jwt', {session:false}), custom.company, CompanyController.remove); // D 33 | 34 | router.get('/dash', passport.authenticate('jwt', {session:false}),HomeController.Dashboard) 35 | 36 | 37 | //********* API DOCUMENTATION ********** 38 | router.use('/docs/api.json', express.static(path.join(__dirname, '/../public/v1/documentation/api.json'))); 39 | router.use('/docs', express.static(path.join(__dirname, '/../public/v1/documentation/dist'))); 40 | module.exports = router; 41 | -------------------------------------------------------------------------------- /services/auth.service.js: -------------------------------------------------------------------------------- 1 | const { User } = require('../models'); 2 | const validator = require('validator'); 3 | const { to, TE } = require('../services/util.service'); 4 | 5 | const getUniqueKeyFromBody = function(body){// this is so they can send in 3 options unique_key, email, or phone and it will work 6 | let unique_key = body.unique_key; 7 | if(typeof unique_key==='undefined'){ 8 | if(typeof body.email != 'undefined'){ 9 | unique_key = body.email 10 | }else if(typeof body.phone != 'undefined'){ 11 | unique_key = body.phone 12 | }else{ 13 | unique_key = null; 14 | } 15 | } 16 | 17 | return unique_key; 18 | } 19 | module.exports.getUniqueKeyFromBody = getUniqueKeyFromBody; 20 | 21 | const createUser = async (userInfo) => { 22 | let unique_key, auth_info, err; 23 | 24 | auth_info={}; 25 | auth_info.status='create'; 26 | 27 | unique_key = getUniqueKeyFromBody(userInfo); 28 | if(!unique_key) TE('An email or phone number was not entered.'); 29 | 30 | if(validator.isEmail(unique_key)){ 31 | auth_info.method = 'email'; 32 | userInfo.email = unique_key; 33 | 34 | [err, user] = await to(User.create(userInfo)); 35 | if(err) TE('user already exists with that email'); 36 | 37 | return user; 38 | 39 | }else if(validator.isMobilePhone(unique_key, 'any')){//checks if only phone number was sent 40 | auth_info.method = 'phone'; 41 | userInfo.phone = unique_key; 42 | 43 | [err, user] = await to(User.create(userInfo)); 44 | if(err) TE('user already exists with that phone number'); 45 | 46 | return user; 47 | }else{ 48 | TE('A valid email or phone number was not entered.'); 49 | } 50 | } 51 | module.exports.createUser = createUser; 52 | 53 | const authUser = async function(userInfo){//returns token 54 | let unique_key; 55 | let auth_info = {}; 56 | auth_info.status = 'login'; 57 | unique_key = getUniqueKeyFromBody(userInfo); 58 | 59 | if(!unique_key) TE('Please enter an email or phone number to login'); 60 | 61 | 62 | if(!userInfo.password) TE('Please enter a password to login'); 63 | 64 | let user; 65 | if(validator.isEmail(unique_key)){ 66 | auth_info.method='email'; 67 | 68 | [err, user] = await to(User.findOne({where:{email:unique_key}})); 69 | if(err) TE(err.message); 70 | 71 | }else if(validator.isMobilePhone(unique_key, 'any')){//checks if only phone number was sent 72 | auth_info.method='phone'; 73 | 74 | [err, user] = await to(User.findOne({where:{phone:unique_key }})); 75 | if(err) TE(err.message); 76 | 77 | }else{ 78 | TE('A valid email or phone number was not entered'); 79 | } 80 | 81 | if(!user) TE('Not registered'); 82 | 83 | [err, user] = await to(user.comparePassword(userInfo.password)); 84 | 85 | if(err) TE(err.message); 86 | 87 | return user; 88 | 89 | } 90 | module.exports.authUser = authUser; -------------------------------------------------------------------------------- /services/util.service.js: -------------------------------------------------------------------------------- 1 | const {to} = require('await-to-js'); 2 | const pe = require('parse-error'); 3 | 4 | module.exports.to = async (promise) => { 5 | let err, res; 6 | [err, res] = await to(promise); 7 | if(err) return [pe(err)]; 8 | 9 | return [null, res]; 10 | }; 11 | 12 | module.exports.ReE = function(res, err, code){ // Error Web Response 13 | if(typeof err == 'object' && typeof err.message != 'undefined'){ 14 | err = err.message; 15 | } 16 | 17 | if(typeof code !== 'undefined') res.statusCode = code; 18 | 19 | return res.json({success:false, error: err}); 20 | }; 21 | 22 | module.exports.ReS = function(res, data, code){ // Success Web Response 23 | let send_data = {success:true}; 24 | 25 | if(typeof data == 'object'){ 26 | send_data = Object.assign(data, send_data);//merge the objects 27 | } 28 | 29 | if(typeof code !== 'undefined') res.statusCode = code; 30 | 31 | return res.json(send_data) 32 | }; 33 | 34 | module.exports.TE = TE = function(err_message, log){ // TE stands for Throw Error 35 | if(log === true){ 36 | console.error(err_message); 37 | } 38 | 39 | throw new Error(err_message); 40 | }; 41 | 42 | 43 | --------------------------------------------------------------------------------