├── .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 ├── 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. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Rest Api Node and Mongo 2 | 3 | ## Description 4 | This is an Restful API for Node.js and Mongo. Designed after PHP's beautiful Laravel. This is in the MVC format, 5 | except because it is an API there are no views, just models and controllers. 6 | 7 | tutorial can be found here: https://medium.com/@brianalois/build-node-mongo-rest-api-2018-jwt-eff0e4f41007 8 | ##### Routing : Express 9 | ##### ODM Database : Mongoose 10 | ##### Authentication : Passport, JWT 11 | 12 | ## Installation 13 | 14 | #### Donwload Code | Clone the Repo 15 | 16 | ``` 17 | git clone {repo_name} 18 | ``` 19 | 20 | #### Install Node Modules 21 | ``` 22 | npm install 23 | ``` 24 | 25 | #### Create .env File 26 | 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. 27 | Fill in the variables to fit your application 28 | 29 | -------------------------------------------------------------------------------- /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 | const v1 = require('./routes/v1'); 8 | 9 | const app = express(); 10 | 11 | const CONFIG = require('./config/config'); 12 | app.use(logger('dev')); 13 | app.use(bodyParser.json()); 14 | app.use(bodyParser.urlencoded({ extended: false })); 15 | // app.use(cookieParser()); 16 | // app.use(express.static(path.join(__dirname, 'public'))); 17 | 18 | //Passport 19 | app.use(passport.initialize()); 20 | 21 | //Log Env 22 | console.log("Environment:", CONFIG.app) 23 | //DATABASE 24 | const models = require("./models"); 25 | 26 | // CORS 27 | app.use(cors()); 28 | 29 | app.use('/v1', v1); 30 | 31 | app.use('/', function(req, res){ 32 | res.statusCode = 200;//send the appropriate status code 33 | res.json({status:"success", message:"Mongo API", data:{}}) 34 | }); 35 | 36 | // catch 404 and forward to error handler 37 | app.use(function(req, res, next) { 38 | var err = new Error('Not Found'); 39 | err.status = 404; 40 | next(err); 41 | }); 42 | 43 | // error handler 44 | app.use(function(err, req, res, next) { 45 | // set locals, only providing error in development 46 | res.locals.message = err.message; 47 | res.locals.error = req.app.get('env') === 'development' ? err : {}; 48 | 49 | // render the error page 50 | res.status(err.status || 500); 51 | res.render('error'); 52 | }); 53 | 54 | module.exports = app; 55 | 56 | process.on('unhandledRejection', error => { 57 | console.error('Uncaught Error', pe(error)); 58 | }); 59 | -------------------------------------------------------------------------------- /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 | 4 | let CONFIG = {} //Make this global to use all over the application 5 | 6 | CONFIG.app = process.env.APP || 'development'; 7 | CONFIG.port = process.env.PORT || '3000'; 8 | 9 | CONFIG.db_dialect = process.env.DB_DIALECT || 'mongo'; 10 | CONFIG.db_host = process.env.DB_HOST || 'localhost'; 11 | CONFIG.db_port = process.env.DB_PORT || '27017'; 12 | CONFIG.db_name = process.env.DB_NAME || 'name'; 13 | CONFIG.db_user = process.env.DB_USER || 'root'; 14 | CONFIG.db_password = process.env.DB_PASSWORD || 'db-password'; 15 | 16 | CONFIG.jwt_encryption = process.env.JWT_ENCRYPTION || 'jwt_please_change'; 17 | CONFIG.jwt_expiration = process.env.JWT_EXPIRATION || '10000'; 18 | 19 | module.exports = CONFIG; 20 | -------------------------------------------------------------------------------- /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 | res.setHeader('Content-Type', 'application/json'); 6 | let err, company; 7 | let user = req.user; 8 | 9 | let company_info = req.body; 10 | company_info.users = [{user:user._id}]; 11 | 12 | [err, company] = await to(Company.create(company_info)); 13 | if(err) return ReE(res, err, 422); 14 | 15 | return ReS(res,{company:company.toWeb()}, 201); 16 | } 17 | module.exports.create = create; 18 | 19 | const getAll = async function(req, res){ 20 | res.setHeader('Content-Type', 'application/json'); 21 | let user = req.user; 22 | let err, companies; 23 | [err, companies] = await to(user.Companies()); 24 | 25 | let companies_json = [] 26 | for (let i in companies){ 27 | let company = companies[i]; 28 | companies_json.push(company.toWeb()) 29 | } 30 | return ReS(res, {companies: companies_json}); 31 | } 32 | module.exports.getAll = getAll; 33 | 34 | const get = function(req, res){ 35 | res.setHeader('Content-Type', 'application/json'); 36 | let company = req.company; 37 | return ReS(res, {company:company.toWeb()}); 38 | } 39 | module.exports.get = get; 40 | 41 | const update = async function(req, res){ 42 | let err, company, data; 43 | company = req.user; 44 | data = req.body; 45 | company.set(data); 46 | 47 | [err, company] = await to(company.save()); 48 | if(err){ 49 | return ReE(res, err); 50 | } 51 | return ReS(res, {company:company.toWeb()}); 52 | } 53 | module.exports.update = update; 54 | 55 | const remove = async function(req, res){ 56 | let company, err; 57 | company = req.company; 58 | 59 | [err, company] = await to(company.remove()); 60 | if(err) return ReE(res, 'error occured trying to delete the company'); 61 | 62 | return ReS(res, {message:'Deleted Company'}, 204); 63 | } 64 | 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 | res.setHeader('Content-Type', 'application/json'); 7 | const body = req.body; 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 | res.setHeader('Content-Type', 'application/json'); 25 | let user = req.user; 26 | 27 | return ReS(res, {user:user.toWeb()}); 28 | } 29 | module.exports.get = get; 30 | 31 | const update = async function(req, res){ 32 | let err, user, data 33 | user = req.user; 34 | data = req.body; 35 | user.set(data); 36 | 37 | [err, user] = await to(user.save()); 38 | if(err){ 39 | console.log(err, user); 40 | 41 | if(err.message.includes('E11000')){ 42 | if(err.message.includes('phone')){ 43 | err = 'This phone number is already in use'; 44 | } else if(err.message.includes('email')){ 45 | err = 'This email address is already in use'; 46 | }else{ 47 | err = 'Duplicate Key Entry'; 48 | } 49 | } 50 | 51 | return ReE(res, err); 52 | } 53 | return ReS(res, {message :'Updated User: '+user.email}); 54 | } 55 | module.exports.update = update; 56 | 57 | const remove = async function(req, res){ 58 | let user, err; 59 | user = req.user; 60 | 61 | [err, user] = await to(user.destroy()); 62 | if(err) return ReE(res, 'error occured trying to delete user'); 63 | 64 | return ReS(res, {message:'Deleted User'}, 204); 65 | } 66 | module.exports.remove = remove; 67 | 68 | 69 | const login = async function(req, res){ 70 | const body = req.body; 71 | let err, user; 72 | 73 | [err, user] = await to(authService.authUser(req.body)); 74 | if(err) return ReE(res, err, 422); 75 | 76 | return ReS(res, {token:user.getJWT(), user:user.toWeb()}); 77 | } 78 | module.exports.login = login; -------------------------------------------------------------------------------- /example.env: -------------------------------------------------------------------------------- 1 | APP=dev 2 | PORT=3000 3 | 4 | DB_DIALECT=mongo 5 | DB_HOST=localhost 6 | DB_PORT=27017 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.model'); 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({_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; 13 | user = req.user; 14 | users_array = company.users.map(obj=>String(obj.user)); 15 | 16 | if(!users_array.includes(String(user._id))) return ReE(res, "User does not have permission to read app with id: "+app_id); 17 | 18 | req.company = company; 19 | next(); 20 | } 21 | 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 | if(err) return done(err, false); 15 | if(user) { 16 | return done(null, user); 17 | }else{ 18 | return done(null, false); 19 | } 20 | })); 21 | } -------------------------------------------------------------------------------- /models/company.model.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const {TE, to} = require('../services/util.service'); 3 | 4 | let CompanySchema = mongoose.Schema({ 5 | name: {type:String}, 6 | users: [ {user:{type : mongoose.Schema.ObjectId, ref : 'User'}, permissions:[{type:String}]} ], 7 | }, {timestamps: true}); 8 | 9 | CompanySchema.methods.toWeb = function(){ 10 | let json = this.toJSON(); 11 | json.id = this._id;//this is for the front end 12 | return json; 13 | }; 14 | 15 | let company = module.exports = mongoose.model('Company', CompanySchema); 16 | 17 | -------------------------------------------------------------------------------- /models/index.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs'); 2 | const path = require('path'); 3 | const basename = path.basename(__filename); 4 | const models = {}; 5 | const mongoose = require('mongoose'); 6 | const CONFIG = require('../config/config'); 7 | 8 | if(CONFIG.db_host != ''){ 9 | let files = fs 10 | .readdirSync(__dirname) 11 | .filter((file) => { 12 | return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js'); 13 | }) 14 | .forEach((file) => { 15 | var filename = file.split('.')[0]; 16 | var model_name = filename.charAt(0).toUpperCase() + filename.slice(1); 17 | models[model_name] = require('./'+file); 18 | }); 19 | 20 | mongoose.Promise = global.Promise; //set mongo up to use promises 21 | const mongo_location = 'mongodb://'+CONFIG.db_host+':'+CONFIG.db_port+'/'+CONFIG.db_name; 22 | 23 | mongoose.connect(mongo_location).catch((err)=>{ 24 | console.log('*** Can Not Connect to Mongo Server:', mongo_location) 25 | }) 26 | 27 | let db = mongoose.connection; 28 | module.exports = db; 29 | db.once('open', ()=>{ 30 | console.log('Connected to mongo at '+mongo_location); 31 | }) 32 | db.on('error', (error)=>{ 33 | console.log("error", error); 34 | }) 35 | // End of Mongoose Setup 36 | }else{ 37 | console.log("No Mongo Credentials Given"); 38 | } 39 | 40 | module.exports = models; 41 | -------------------------------------------------------------------------------- /models/user.model.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const bcrypt = require('bcrypt'); 3 | const bcrypt_p = require('bcrypt-promise'); 4 | const jwt = require('jsonwebtoken'); 5 | const Company = require('./company.model'); 6 | const validate = require('mongoose-validator'); 7 | const {TE, to} = require('../services/util.service'); 8 | const CONFIG = require('../config/config'); 9 | 10 | let UserSchema = mongoose.Schema({ 11 | first: {type:String}, 12 | last: {type:String}, 13 | phone: {type:String, lowercase:true, trim: true, index: true, unique: true, sparse: true,//sparse is because now we have two possible unique keys that are optional 14 | validate:[validate({ 15 | validator: 'isNumeric', 16 | arguments: [7, 20], 17 | message: 'Not a valid phone number.', 18 | })] 19 | }, 20 | email: {type:String, lowercase:true, trim: true, index: true, unique: true, sparse: true, 21 | validate:[validate({ 22 | validator: 'isEmail', 23 | message: 'Not a valid email.', 24 | }),] 25 | }, 26 | password: {type:String}, 27 | 28 | }, {timestamps: true}); 29 | 30 | UserSchema.virtual('companies', { 31 | ref: 'Company', 32 | localField: '_id', 33 | foreignField: 'users.user', 34 | justOne: false, 35 | }); 36 | 37 | UserSchema.pre('save', async function(next){ 38 | 39 | if(this.isModified('password') || this.isNew){ 40 | 41 | let err, salt, hash; 42 | [err, salt] = await to(bcrypt.genSalt(10)); 43 | if(err) TE(err.message, true); 44 | 45 | [err, hash] = await to(bcrypt.hash(this.password, salt)); 46 | if(err) TE(err.message, true); 47 | 48 | this.password = hash; 49 | 50 | } else{ 51 | return next(); 52 | } 53 | }) 54 | 55 | UserSchema.methods.comparePassword = async function(pw){ 56 | let err, pass; 57 | if(!this.password) TE('password not set'); 58 | 59 | [err, pass] = await to(bcrypt_p.compare(pw, this.password)); 60 | if(err) TE(err); 61 | 62 | if(!pass) TE('invalid password'); 63 | 64 | return this; 65 | } 66 | 67 | UserSchema.methods.Companies = async function(){ 68 | let err, companies; 69 | [err, companies] = await to(Company.find({'users.user':this._id})); 70 | if(err) TE('err getting companies'); 71 | return companies; 72 | } 73 | 74 | UserSchema.virtual('full_name').set(function (name) { 75 | var split = name.split(' '); 76 | this.first = split[0]; 77 | this.last = split[1]; 78 | }); 79 | 80 | UserSchema.virtual('full_name').get(function () { //now you can treat as if this was a property instead of a function 81 | if(!this.first) return null; 82 | if(!this.last) return this.first; 83 | 84 | return this.first + ' ' + this.last; 85 | }); 86 | 87 | UserSchema.methods.getJWT = function(){ 88 | let expiration_time = parseInt(CONFIG.jwt_expiration); 89 | return "Bearer "+jwt.sign({user_id:this._id}, CONFIG.jwt_encryption, {expiresIn: expiration_time}); 90 | }; 91 | 92 | UserSchema.methods.toWeb = function(){ 93 | let json = this.toJSON(); 94 | json.id = this._id;//this is for the front end 95 | return json; 96 | }; 97 | 98 | let User = module.exports = mongoose.model('User', UserSchema); 99 | 100 | 101 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "0.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "abbrev": { 8 | "version": "1.1.1", 9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 11 | }, 12 | "accepts": { 13 | "version": "1.3.4", 14 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.4.tgz", 15 | "integrity": "sha1-hiRnWMfdbSGmR0/whKR0DsBesh8=", 16 | "requires": { 17 | "mime-types": "2.1.17", 18 | "negotiator": "0.6.1" 19 | } 20 | }, 21 | "acorn": { 22 | "version": "2.7.0", 23 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-2.7.0.tgz", 24 | "integrity": "sha1-q259nYhqrKiwhbwzEreaGYQz8Oc=" 25 | }, 26 | "acorn-globals": { 27 | "version": "1.0.9", 28 | "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-1.0.9.tgz", 29 | "integrity": "sha1-VbtemGkVB7dFedBRNBMhfDgMVM8=", 30 | "requires": { 31 | "acorn": "2.7.0" 32 | } 33 | }, 34 | "ajv": { 35 | "version": "5.2.4", 36 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.2.4.tgz", 37 | "integrity": "sha1-Pa+ai2ciEpn9ro2C0RftjmyAJEs=", 38 | "requires": { 39 | "co": "4.6.0", 40 | "fast-deep-equal": "1.0.0", 41 | "json-schema-traverse": "0.3.1", 42 | "json-stable-stringify": "1.0.1" 43 | } 44 | }, 45 | "align-text": { 46 | "version": "0.1.4", 47 | "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", 48 | "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", 49 | "requires": { 50 | "kind-of": "3.2.2", 51 | "longest": "1.0.1", 52 | "repeat-string": "1.6.1" 53 | } 54 | }, 55 | "amdefine": { 56 | "version": "1.0.1", 57 | "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", 58 | "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=" 59 | }, 60 | "ansi-regex": { 61 | "version": "2.1.1", 62 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 63 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 64 | }, 65 | "aproba": { 66 | "version": "1.2.0", 67 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 68 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 69 | }, 70 | "are-we-there-yet": { 71 | "version": "1.1.4", 72 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz", 73 | "integrity": "sha1-u13KOCu5TwXhUZQ3PRb9O6HKEQ0=", 74 | "requires": { 75 | "delegates": "1.0.0", 76 | "readable-stream": "2.2.7" 77 | } 78 | }, 79 | "array-flatten": { 80 | "version": "1.1.1", 81 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 82 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 83 | }, 84 | "asap": { 85 | "version": "1.0.0", 86 | "resolved": "https://registry.npmjs.org/asap/-/asap-1.0.0.tgz", 87 | "integrity": "sha1-sqRdpf36ILBJb8N2jMJ8EvqRan0=" 88 | }, 89 | "asn1": { 90 | "version": "0.2.3", 91 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", 92 | "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=" 93 | }, 94 | "assert-plus": { 95 | "version": "1.0.0", 96 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 97 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 98 | }, 99 | "async": { 100 | "version": "2.1.4", 101 | "resolved": "https://registry.npmjs.org/async/-/async-2.1.4.tgz", 102 | "integrity": "sha1-LSFgx3iAMuTdbL4lAvH5osj2zeQ=", 103 | "requires": { 104 | "lodash": "4.17.4" 105 | } 106 | }, 107 | "asynckit": { 108 | "version": "0.4.0", 109 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 110 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 111 | }, 112 | "await-to-js": { 113 | "version": "2.0.1", 114 | "resolved": "https://registry.npmjs.org/await-to-js/-/await-to-js-2.0.1.tgz", 115 | "integrity": "sha512-zJIZ/G2/sghdDWRMFO2R1Qn4RBPl/OEIe2Cfiz/VXfQS0lmyZwrq4Wmxai4KpvtnsijIadzttwjaSfg1s3CcLQ==" 116 | }, 117 | "aws-sign2": { 118 | "version": "0.7.0", 119 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 120 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 121 | }, 122 | "aws4": { 123 | "version": "1.6.0", 124 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", 125 | "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=" 126 | }, 127 | "balanced-match": { 128 | "version": "1.0.0", 129 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 130 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 131 | }, 132 | "base64url": { 133 | "version": "2.0.0", 134 | "resolved": "https://registry.npmjs.org/base64url/-/base64url-2.0.0.tgz", 135 | "integrity": "sha1-6sFuA+oUOO/5Qj1puqNiYu0fcLs=" 136 | }, 137 | "basic-auth": { 138 | "version": "2.0.0", 139 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.0.tgz", 140 | "integrity": "sha1-AV2z81PgLlY3d1X5YnQuiYHnu7o=", 141 | "requires": { 142 | "safe-buffer": "5.1.1" 143 | } 144 | }, 145 | "bcrypt": { 146 | "version": "1.0.3", 147 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-1.0.3.tgz", 148 | "integrity": "sha512-pRyDdo73C8Nim3jwFJ7DWe3TZCgwDfWZ6nHS5LSdU77kWbj1frruvdndP02AOavtD4y8v6Fp2dolbHgp4SDrfg==", 149 | "requires": { 150 | "nan": "2.6.2", 151 | "node-pre-gyp": "0.6.36" 152 | } 153 | }, 154 | "bcrypt-pbkdf": { 155 | "version": "1.0.1", 156 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", 157 | "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", 158 | "optional": true, 159 | "requires": { 160 | "tweetnacl": "0.14.5" 161 | } 162 | }, 163 | "bcrypt-promise": { 164 | "version": "2.0.0", 165 | "resolved": "https://registry.npmjs.org/bcrypt-promise/-/bcrypt-promise-2.0.0.tgz", 166 | "integrity": "sha1-oLaD6UNCEArubuaXF0Oj4Xna4nw=" 167 | }, 168 | "block-stream": { 169 | "version": "0.0.9", 170 | "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", 171 | "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", 172 | "requires": { 173 | "inherits": "2.0.3" 174 | } 175 | }, 176 | "body-parser": { 177 | "version": "1.18.2", 178 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.2.tgz", 179 | "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=", 180 | "requires": { 181 | "bytes": "3.0.0", 182 | "content-type": "1.0.4", 183 | "debug": "2.6.9", 184 | "depd": "1.1.1", 185 | "http-errors": "1.6.2", 186 | "iconv-lite": "0.4.19", 187 | "on-finished": "2.3.0", 188 | "qs": "6.5.1", 189 | "raw-body": "2.3.2", 190 | "type-is": "1.6.15" 191 | } 192 | }, 193 | "boom": { 194 | "version": "4.3.1", 195 | "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", 196 | "integrity": "sha1-T4owBctKfjiJ90kDD9JbluAdLjE=", 197 | "requires": { 198 | "hoek": "4.2.0" 199 | } 200 | }, 201 | "brace-expansion": { 202 | "version": "1.1.8", 203 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 204 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 205 | "requires": { 206 | "balanced-match": "1.0.0", 207 | "concat-map": "0.0.1" 208 | } 209 | }, 210 | "bson": { 211 | "version": "1.0.4", 212 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.0.4.tgz", 213 | "integrity": "sha1-k8ENOeqltYQVy8QFLz5T5WKwtyw=" 214 | }, 215 | "buffer-equal-constant-time": { 216 | "version": "1.0.1", 217 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 218 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 219 | }, 220 | "buffer-shims": { 221 | "version": "1.0.0", 222 | "resolved": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz", 223 | "integrity": "sha1-mXjOMXOIxkmth5MCjDR37wRKi1E=" 224 | }, 225 | "bytes": { 226 | "version": "3.0.0", 227 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 228 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 229 | }, 230 | "camelcase": { 231 | "version": "1.2.1", 232 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", 233 | "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=" 234 | }, 235 | "caseless": { 236 | "version": "0.12.0", 237 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 238 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 239 | }, 240 | "center-align": { 241 | "version": "0.1.3", 242 | "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", 243 | "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", 244 | "requires": { 245 | "align-text": "0.1.4", 246 | "lazy-cache": "1.0.4" 247 | } 248 | }, 249 | "character-parser": { 250 | "version": "1.2.1", 251 | "resolved": "https://registry.npmjs.org/character-parser/-/character-parser-1.2.1.tgz", 252 | "integrity": "sha1-wN3kqxgnE7kZuXCVmhI+zBow/NY=" 253 | }, 254 | "clean-css": { 255 | "version": "3.4.28", 256 | "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-3.4.28.tgz", 257 | "integrity": "sha1-vxlF6C/ICPVWlebd6uwBQA79A/8=", 258 | "requires": { 259 | "commander": "2.8.1", 260 | "source-map": "0.4.4" 261 | }, 262 | "dependencies": { 263 | "commander": { 264 | "version": "2.8.1", 265 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.8.1.tgz", 266 | "integrity": "sha1-Br42f+v9oMMwqh4qBy09yXYkJdQ=", 267 | "requires": { 268 | "graceful-readlink": "1.0.1" 269 | } 270 | } 271 | } 272 | }, 273 | "cliui": { 274 | "version": "2.1.0", 275 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", 276 | "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", 277 | "requires": { 278 | "center-align": "0.1.3", 279 | "right-align": "0.1.3", 280 | "wordwrap": "0.0.2" 281 | }, 282 | "dependencies": { 283 | "wordwrap": { 284 | "version": "0.0.2", 285 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", 286 | "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=" 287 | } 288 | } 289 | }, 290 | "co": { 291 | "version": "4.6.0", 292 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 293 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" 294 | }, 295 | "code-point-at": { 296 | "version": "1.1.0", 297 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 298 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 299 | }, 300 | "combined-stream": { 301 | "version": "1.0.5", 302 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 303 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 304 | "requires": { 305 | "delayed-stream": "1.0.0" 306 | } 307 | }, 308 | "commander": { 309 | "version": "2.6.0", 310 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.6.0.tgz", 311 | "integrity": "sha1-nfflL7Kgyw+4kFjugMMQQiXzfh0=" 312 | }, 313 | "concat-map": { 314 | "version": "0.0.1", 315 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 316 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 317 | }, 318 | "console-control-strings": { 319 | "version": "1.1.0", 320 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 321 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 322 | }, 323 | "constantinople": { 324 | "version": "3.0.2", 325 | "resolved": "https://registry.npmjs.org/constantinople/-/constantinople-3.0.2.tgz", 326 | "integrity": "sha1-S5RdmTeQe82Y7ldRIsOBdRZUQUE=", 327 | "requires": { 328 | "acorn": "2.7.0" 329 | } 330 | }, 331 | "content-disposition": { 332 | "version": "0.5.2", 333 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 334 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 335 | }, 336 | "content-type": { 337 | "version": "1.0.4", 338 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 339 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 340 | }, 341 | "cookie": { 342 | "version": "0.3.1", 343 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 344 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 345 | }, 346 | "cookie-parser": { 347 | "version": "1.4.3", 348 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.3.tgz", 349 | "integrity": "sha1-D+MfoZ0AC5X0qt8fU/3CuKIDuqU=", 350 | "requires": { 351 | "cookie": "0.3.1", 352 | "cookie-signature": "1.0.6" 353 | } 354 | }, 355 | "cookie-signature": { 356 | "version": "1.0.6", 357 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 358 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 359 | }, 360 | "core-util-is": { 361 | "version": "1.0.2", 362 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 363 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 364 | }, 365 | "cors": { 366 | "version": "2.8.4", 367 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.4.tgz", 368 | "integrity": "sha1-K9OB8usgECAQXNUOpZ2mMJBpRoY=", 369 | "requires": { 370 | "object-assign": "4.1.1", 371 | "vary": "1.1.2" 372 | } 373 | }, 374 | "cryptiles": { 375 | "version": "3.1.2", 376 | "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-3.1.2.tgz", 377 | "integrity": "sha1-qJ+7Ig9c4l7FboxKqKT9e1sNKf4=", 378 | "requires": { 379 | "boom": "5.2.0" 380 | }, 381 | "dependencies": { 382 | "boom": { 383 | "version": "5.2.0", 384 | "resolved": "https://registry.npmjs.org/boom/-/boom-5.2.0.tgz", 385 | "integrity": "sha512-Z5BTk6ZRe4tXXQlkqftmsAUANpXmuwlsF5Oov8ThoMbQRzdGTA1ngYRW160GexgOgjsFOKJz0LYhoNi+2AMBUw==", 386 | "requires": { 387 | "hoek": "4.2.0" 388 | } 389 | } 390 | } 391 | }, 392 | "css": { 393 | "version": "1.0.8", 394 | "resolved": "https://registry.npmjs.org/css/-/css-1.0.8.tgz", 395 | "integrity": "sha1-k4aBHKgrzMnuf7WnMrHioxfIo+c=", 396 | "requires": { 397 | "css-parse": "1.0.4", 398 | "css-stringify": "1.0.5" 399 | } 400 | }, 401 | "css-parse": { 402 | "version": "1.0.4", 403 | "resolved": "https://registry.npmjs.org/css-parse/-/css-parse-1.0.4.tgz", 404 | "integrity": "sha1-OLBQP7+dqfVOnB29pg4UXHcRe90=" 405 | }, 406 | "css-stringify": { 407 | "version": "1.0.5", 408 | "resolved": "https://registry.npmjs.org/css-stringify/-/css-stringify-1.0.5.tgz", 409 | "integrity": "sha1-sNBClG2ylTu50pKQCmy19tASIDE=" 410 | }, 411 | "dashdash": { 412 | "version": "1.14.1", 413 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 414 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 415 | "requires": { 416 | "assert-plus": "1.0.0" 417 | } 418 | }, 419 | "debug": { 420 | "version": "2.6.9", 421 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 422 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 423 | "requires": { 424 | "ms": "2.0.0" 425 | } 426 | }, 427 | "decamelize": { 428 | "version": "1.2.0", 429 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 430 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 431 | }, 432 | "deep-extend": { 433 | "version": "0.4.2", 434 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.4.2.tgz", 435 | "integrity": "sha1-SLaZwn4zS/ifEIkr5DL25MfTSn8=" 436 | }, 437 | "delayed-stream": { 438 | "version": "1.0.0", 439 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 440 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 441 | }, 442 | "delegates": { 443 | "version": "1.0.0", 444 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 445 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 446 | }, 447 | "depd": { 448 | "version": "1.1.1", 449 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz", 450 | "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=" 451 | }, 452 | "destroy": { 453 | "version": "1.0.4", 454 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 455 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 456 | }, 457 | "dotenv": { 458 | "version": "4.0.0", 459 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-4.0.0.tgz", 460 | "integrity": "sha1-hk7xN5rO1Vzm+V3r7NzhefegzR0=" 461 | }, 462 | "ecc-jsbn": { 463 | "version": "0.1.1", 464 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", 465 | "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", 466 | "optional": true, 467 | "requires": { 468 | "jsbn": "0.1.1" 469 | } 470 | }, 471 | "ecdsa-sig-formatter": { 472 | "version": "1.0.9", 473 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.9.tgz", 474 | "integrity": "sha1-S8kmJ07Dtau1AW5+HWCSGsJisqE=", 475 | "requires": { 476 | "base64url": "2.0.0", 477 | "safe-buffer": "5.1.1" 478 | } 479 | }, 480 | "ee-first": { 481 | "version": "1.1.1", 482 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 483 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 484 | }, 485 | "encodeurl": { 486 | "version": "1.0.1", 487 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", 488 | "integrity": "sha1-eePVhlU0aQn+bw9Fpd5oEDspTSA=" 489 | }, 490 | "escape-html": { 491 | "version": "1.0.3", 492 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 493 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 494 | }, 495 | "etag": { 496 | "version": "1.8.1", 497 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 498 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 499 | }, 500 | "express": { 501 | "version": "4.15.5", 502 | "resolved": "https://registry.npmjs.org/express/-/express-4.15.5.tgz", 503 | "integrity": "sha1-ZwI1ypWYiQpa6BcLg9tyK4Qu2Sc=", 504 | "requires": { 505 | "accepts": "1.3.4", 506 | "array-flatten": "1.1.1", 507 | "content-disposition": "0.5.2", 508 | "content-type": "1.0.4", 509 | "cookie": "0.3.1", 510 | "cookie-signature": "1.0.6", 511 | "debug": "2.6.9", 512 | "depd": "1.1.1", 513 | "encodeurl": "1.0.1", 514 | "escape-html": "1.0.3", 515 | "etag": "1.8.1", 516 | "finalhandler": "1.0.6", 517 | "fresh": "0.5.2", 518 | "merge-descriptors": "1.0.1", 519 | "methods": "1.1.2", 520 | "on-finished": "2.3.0", 521 | "parseurl": "1.3.2", 522 | "path-to-regexp": "0.1.7", 523 | "proxy-addr": "1.1.5", 524 | "qs": "6.5.0", 525 | "range-parser": "1.2.0", 526 | "send": "0.15.6", 527 | "serve-static": "1.12.6", 528 | "setprototypeof": "1.0.3", 529 | "statuses": "1.3.1", 530 | "type-is": "1.6.15", 531 | "utils-merge": "1.0.0", 532 | "vary": "1.1.2" 533 | }, 534 | "dependencies": { 535 | "qs": { 536 | "version": "6.5.0", 537 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.0.tgz", 538 | "integrity": "sha512-fjVFjW9yhqMhVGwRExCXLhJKrLlkYSaxNWdyc9rmHlrVZbk35YHH312dFd7191uQeXkI3mKLZTIbSvIeFwFemg==" 539 | }, 540 | "statuses": { 541 | "version": "1.3.1", 542 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 543 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 544 | } 545 | } 546 | }, 547 | "extend": { 548 | "version": "3.0.1", 549 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 550 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=" 551 | }, 552 | "extsprintf": { 553 | "version": "1.3.0", 554 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 555 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 556 | }, 557 | "fast-deep-equal": { 558 | "version": "1.0.0", 559 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", 560 | "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=" 561 | }, 562 | "finalhandler": { 563 | "version": "1.0.6", 564 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.0.6.tgz", 565 | "integrity": "sha1-AHrqM9Gk0+QgF/YkhIrVjSEvgU8=", 566 | "requires": { 567 | "debug": "2.6.9", 568 | "encodeurl": "1.0.1", 569 | "escape-html": "1.0.3", 570 | "on-finished": "2.3.0", 571 | "parseurl": "1.3.2", 572 | "statuses": "1.3.1", 573 | "unpipe": "1.0.0" 574 | }, 575 | "dependencies": { 576 | "statuses": { 577 | "version": "1.3.1", 578 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 579 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 580 | } 581 | } 582 | }, 583 | "forever-agent": { 584 | "version": "0.6.1", 585 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 586 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 587 | }, 588 | "form-data": { 589 | "version": "2.3.1", 590 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", 591 | "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", 592 | "requires": { 593 | "asynckit": "0.4.0", 594 | "combined-stream": "1.0.5", 595 | "mime-types": "2.1.17" 596 | } 597 | }, 598 | "forwarded": { 599 | "version": "0.1.2", 600 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 601 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 602 | }, 603 | "fresh": { 604 | "version": "0.5.2", 605 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 606 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 607 | }, 608 | "fs.realpath": { 609 | "version": "1.0.0", 610 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 611 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 612 | }, 613 | "fstream": { 614 | "version": "1.0.11", 615 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", 616 | "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", 617 | "requires": { 618 | "graceful-fs": "4.1.11", 619 | "inherits": "2.0.3", 620 | "mkdirp": "0.5.1", 621 | "rimraf": "2.6.2" 622 | } 623 | }, 624 | "fstream-ignore": { 625 | "version": "1.0.5", 626 | "resolved": "https://registry.npmjs.org/fstream-ignore/-/fstream-ignore-1.0.5.tgz", 627 | "integrity": "sha1-nDHa40dnAY/h0kmyTa2mfQktoQU=", 628 | "requires": { 629 | "fstream": "1.0.11", 630 | "inherits": "2.0.3", 631 | "minimatch": "3.0.4" 632 | } 633 | }, 634 | "gauge": { 635 | "version": "2.7.4", 636 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 637 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 638 | "requires": { 639 | "aproba": "1.2.0", 640 | "console-control-strings": "1.1.0", 641 | "has-unicode": "2.0.1", 642 | "object-assign": "4.1.1", 643 | "signal-exit": "3.0.2", 644 | "string-width": "1.0.2", 645 | "strip-ansi": "3.0.1", 646 | "wide-align": "1.1.2" 647 | } 648 | }, 649 | "getpass": { 650 | "version": "0.1.7", 651 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 652 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 653 | "requires": { 654 | "assert-plus": "1.0.0" 655 | } 656 | }, 657 | "glob": { 658 | "version": "7.1.2", 659 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 660 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 661 | "requires": { 662 | "fs.realpath": "1.0.0", 663 | "inflight": "1.0.6", 664 | "inherits": "2.0.3", 665 | "minimatch": "3.0.4", 666 | "once": "1.4.0", 667 | "path-is-absolute": "1.0.1" 668 | } 669 | }, 670 | "graceful-fs": { 671 | "version": "4.1.11", 672 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 673 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" 674 | }, 675 | "graceful-readlink": { 676 | "version": "1.0.1", 677 | "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz", 678 | "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=" 679 | }, 680 | "har-schema": { 681 | "version": "2.0.0", 682 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 683 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 684 | }, 685 | "har-validator": { 686 | "version": "5.0.3", 687 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.0.3.tgz", 688 | "integrity": "sha1-ukAsJmGU8VlW7xXg/PJCmT9qff0=", 689 | "requires": { 690 | "ajv": "5.2.4", 691 | "har-schema": "2.0.0" 692 | } 693 | }, 694 | "has-unicode": { 695 | "version": "2.0.1", 696 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 697 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 698 | }, 699 | "hawk": { 700 | "version": "6.0.2", 701 | "resolved": "https://registry.npmjs.org/hawk/-/hawk-6.0.2.tgz", 702 | "integrity": "sha512-miowhl2+U7Qle4vdLqDdPt9m09K6yZhkLDTWGoUiUzrQCn+mHHSmfJgAyGaLRZbPmTqfFFjRV1QWCW0VWUJBbQ==", 703 | "requires": { 704 | "boom": "4.3.1", 705 | "cryptiles": "3.1.2", 706 | "hoek": "4.2.0", 707 | "sntp": "2.0.2" 708 | } 709 | }, 710 | "hoek": { 711 | "version": "4.2.0", 712 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.0.tgz", 713 | "integrity": "sha512-v0XCLxICi9nPfYrS9RL8HbYnXi9obYAeLbSP00BmnZwCK9+Ih9WOjoZ8YoHCoav2csqn4FOz4Orldsy2dmDwmQ==" 714 | }, 715 | "http-errors": { 716 | "version": "1.6.2", 717 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz", 718 | "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=", 719 | "requires": { 720 | "depd": "1.1.1", 721 | "inherits": "2.0.3", 722 | "setprototypeof": "1.0.3", 723 | "statuses": "1.4.0" 724 | } 725 | }, 726 | "http-signature": { 727 | "version": "1.2.0", 728 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 729 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 730 | "requires": { 731 | "assert-plus": "1.0.0", 732 | "jsprim": "1.4.1", 733 | "sshpk": "1.13.1" 734 | } 735 | }, 736 | "iconv-lite": { 737 | "version": "0.4.19", 738 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 739 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==" 740 | }, 741 | "inflight": { 742 | "version": "1.0.6", 743 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 744 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 745 | "requires": { 746 | "once": "1.4.0", 747 | "wrappy": "1.0.2" 748 | } 749 | }, 750 | "inherits": { 751 | "version": "2.0.3", 752 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 753 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 754 | }, 755 | "ini": { 756 | "version": "1.3.4", 757 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.4.tgz", 758 | "integrity": "sha1-BTfLedr1m1mhpRff9wbIbsA5Fi4=" 759 | }, 760 | "ipaddr.js": { 761 | "version": "1.4.0", 762 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.4.0.tgz", 763 | "integrity": "sha1-KWrKh4qCGBbluF0KKFqZvP9FgvA=" 764 | }, 765 | "is": { 766 | "version": "3.2.1", 767 | "resolved": "https://registry.npmjs.org/is/-/is-3.2.1.tgz", 768 | "integrity": "sha1-0Kwq1V63sL7JJqUmb2xmKqqD3KU=" 769 | }, 770 | "is-buffer": { 771 | "version": "1.1.5", 772 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.5.tgz", 773 | "integrity": "sha1-Hzsm72E7IUuIy8ojzGwB2Hlh7sw=" 774 | }, 775 | "is-fullwidth-code-point": { 776 | "version": "1.0.0", 777 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 778 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 779 | "requires": { 780 | "number-is-nan": "1.0.1" 781 | } 782 | }, 783 | "is-promise": { 784 | "version": "2.1.0", 785 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 786 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 787 | }, 788 | "is-typedarray": { 789 | "version": "1.0.0", 790 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 791 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 792 | }, 793 | "isarray": { 794 | "version": "1.0.0", 795 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 796 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 797 | }, 798 | "isemail": { 799 | "version": "1.2.0", 800 | "resolved": "https://registry.npmjs.org/isemail/-/isemail-1.2.0.tgz", 801 | "integrity": "sha1-vgPfjMPineTSxd9lASY/H6RZXpo=" 802 | }, 803 | "isstream": { 804 | "version": "0.1.2", 805 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 806 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 807 | }, 808 | "jade": { 809 | "version": "1.11.0", 810 | "resolved": "https://registry.npmjs.org/jade/-/jade-1.11.0.tgz", 811 | "integrity": "sha1-nIDlOMEtP7lcjZu5VZ+gzAQEBf0=", 812 | "requires": { 813 | "character-parser": "1.2.1", 814 | "clean-css": "3.4.28", 815 | "commander": "2.6.0", 816 | "constantinople": "3.0.2", 817 | "jstransformer": "0.0.2", 818 | "mkdirp": "0.5.1", 819 | "transformers": "2.1.0", 820 | "uglify-js": "2.8.29", 821 | "void-elements": "2.0.1", 822 | "with": "4.0.3" 823 | } 824 | }, 825 | "joi": { 826 | "version": "6.10.1", 827 | "resolved": "https://registry.npmjs.org/joi/-/joi-6.10.1.tgz", 828 | "integrity": "sha1-TVDDGAeRIgAP5fFq8f+OGRe3fgY=", 829 | "requires": { 830 | "hoek": "2.16.3", 831 | "isemail": "1.2.0", 832 | "moment": "2.19.1", 833 | "topo": "1.1.0" 834 | }, 835 | "dependencies": { 836 | "hoek": { 837 | "version": "2.16.3", 838 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", 839 | "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=" 840 | } 841 | } 842 | }, 843 | "jsbn": { 844 | "version": "0.1.1", 845 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 846 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 847 | "optional": true 848 | }, 849 | "json-schema": { 850 | "version": "0.2.3", 851 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 852 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 853 | }, 854 | "json-schema-traverse": { 855 | "version": "0.3.1", 856 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 857 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=" 858 | }, 859 | "json-stable-stringify": { 860 | "version": "1.0.1", 861 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", 862 | "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", 863 | "requires": { 864 | "jsonify": "0.0.0" 865 | } 866 | }, 867 | "json-stringify-safe": { 868 | "version": "5.0.1", 869 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 870 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 871 | }, 872 | "jsonify": { 873 | "version": "0.0.0", 874 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 875 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=" 876 | }, 877 | "jsonwebtoken": { 878 | "version": "7.4.3", 879 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-7.4.3.tgz", 880 | "integrity": "sha1-d/UCHeBYtgWheD+hKD6ZgS5kVjg=", 881 | "requires": { 882 | "joi": "6.10.1", 883 | "jws": "3.1.4", 884 | "lodash.once": "4.1.1", 885 | "ms": "2.0.0", 886 | "xtend": "4.0.1" 887 | } 888 | }, 889 | "jsprim": { 890 | "version": "1.4.1", 891 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 892 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 893 | "requires": { 894 | "assert-plus": "1.0.0", 895 | "extsprintf": "1.3.0", 896 | "json-schema": "0.2.3", 897 | "verror": "1.10.0" 898 | } 899 | }, 900 | "jstransformer": { 901 | "version": "0.0.2", 902 | "resolved": "https://registry.npmjs.org/jstransformer/-/jstransformer-0.0.2.tgz", 903 | "integrity": "sha1-eq4pqQPRls+glz2IXT5HlH7Ndqs=", 904 | "requires": { 905 | "is-promise": "2.1.0", 906 | "promise": "6.1.0" 907 | } 908 | }, 909 | "jwa": { 910 | "version": "1.1.5", 911 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.1.5.tgz", 912 | "integrity": "sha1-oFUs4CIHQs1S4VN3SjKQXDDnVuU=", 913 | "requires": { 914 | "base64url": "2.0.0", 915 | "buffer-equal-constant-time": "1.0.1", 916 | "ecdsa-sig-formatter": "1.0.9", 917 | "safe-buffer": "5.1.1" 918 | } 919 | }, 920 | "jws": { 921 | "version": "3.1.4", 922 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.1.4.tgz", 923 | "integrity": "sha1-+ei5M46KhHJ31kRLFGT2GIDgUKI=", 924 | "requires": { 925 | "base64url": "2.0.0", 926 | "jwa": "1.1.5", 927 | "safe-buffer": "5.1.1" 928 | } 929 | }, 930 | "kareem": { 931 | "version": "2.0.1", 932 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.0.1.tgz", 933 | "integrity": "sha512-SsR+TZe595qXYzbWS5KWHBt4mM5h1MA7HFXp3oZnPkunxjaymx0fKhB8cxl6/R7Qm8aFXnI6J7DnyxV/QUSKLA==" 934 | }, 935 | "kind-of": { 936 | "version": "3.2.2", 937 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 938 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 939 | "requires": { 940 | "is-buffer": "1.1.5" 941 | } 942 | }, 943 | "lazy-cache": { 944 | "version": "1.0.4", 945 | "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", 946 | "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=" 947 | }, 948 | "lodash": { 949 | "version": "4.17.4", 950 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 951 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" 952 | }, 953 | "lodash.get": { 954 | "version": "4.4.2", 955 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 956 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" 957 | }, 958 | "lodash.once": { 959 | "version": "4.1.1", 960 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 961 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 962 | }, 963 | "longest": { 964 | "version": "1.0.1", 965 | "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", 966 | "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=" 967 | }, 968 | "media-typer": { 969 | "version": "0.3.0", 970 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 971 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 972 | }, 973 | "merge-descriptors": { 974 | "version": "1.0.1", 975 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 976 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 977 | }, 978 | "methods": { 979 | "version": "1.1.2", 980 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 981 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 982 | }, 983 | "mime": { 984 | "version": "1.3.4", 985 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.3.4.tgz", 986 | "integrity": "sha1-EV+eO2s9rylZmDyzjxSaLUDrXVM=" 987 | }, 988 | "mime-db": { 989 | "version": "1.30.0", 990 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", 991 | "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=" 992 | }, 993 | "mime-types": { 994 | "version": "2.1.17", 995 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", 996 | "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", 997 | "requires": { 998 | "mime-db": "1.30.0" 999 | } 1000 | }, 1001 | "minimatch": { 1002 | "version": "3.0.4", 1003 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1004 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1005 | "requires": { 1006 | "brace-expansion": "1.1.8" 1007 | } 1008 | }, 1009 | "minimist": { 1010 | "version": "0.0.8", 1011 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1012 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 1013 | }, 1014 | "mkdirp": { 1015 | "version": "0.5.1", 1016 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1017 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1018 | "requires": { 1019 | "minimist": "0.0.8" 1020 | } 1021 | }, 1022 | "moment": { 1023 | "version": "2.19.1", 1024 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.19.1.tgz", 1025 | "integrity": "sha1-VtoaLRy/AdOLfhr8McELz6GSkWc=" 1026 | }, 1027 | "mongodb": { 1028 | "version": "3.0.1", 1029 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.0.1.tgz", 1030 | "integrity": "sha1-J47oAGJX7CJ5hZSmJZVGgl1t4bI=", 1031 | "requires": { 1032 | "mongodb-core": "3.0.1" 1033 | } 1034 | }, 1035 | "mongodb-core": { 1036 | "version": "3.0.1", 1037 | "resolved": "https://registry.npmjs.org/mongodb-core/-/mongodb-core-3.0.1.tgz", 1038 | "integrity": "sha1-/23Dbulv9ZaVPYCmhA1nMbyS7+0=", 1039 | "requires": { 1040 | "bson": "1.0.4", 1041 | "require_optional": "1.0.1" 1042 | } 1043 | }, 1044 | "mongoose": { 1045 | "version": "5.0.1", 1046 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.0.1.tgz", 1047 | "integrity": "sha512-0HcbACameXXwrFmA2+aujJ+S01HYpIx3OUxLE26iw7gk6V7fW2VWFwjAqgCE5fePwSlI/N6vEApMoYuf5E53iw==", 1048 | "requires": { 1049 | "async": "2.1.4", 1050 | "bson": "1.0.4", 1051 | "kareem": "2.0.1", 1052 | "lodash.get": "4.4.2", 1053 | "mongodb": "3.0.1", 1054 | "mongoose-legacy-pluralize": "1.0.1", 1055 | "mpath": "0.3.0", 1056 | "mquery": "3.0.0-rc0", 1057 | "ms": "2.0.0", 1058 | "regexp-clone": "0.0.1", 1059 | "sliced": "1.0.1" 1060 | } 1061 | }, 1062 | "mongoose-legacy-pluralize": { 1063 | "version": "1.0.1", 1064 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.1.tgz", 1065 | "integrity": "sha512-X5/N3sNj1p+y7Bg1vouQdST1vkInEzNAwqVjfDpNrhnugih2p2rV7jLrrb71sbQUPMJPm0Hhe6rH5fQV1Ve4XQ==" 1066 | }, 1067 | "mongoose-validator": { 1068 | "version": "2.0.2", 1069 | "resolved": "https://registry.npmjs.org/mongoose-validator/-/mongoose-validator-2.0.2.tgz", 1070 | "integrity": "sha512-NOpngA5kYj835qerogxQLorziPEdY/HwwT4LKLOkz+E4wrKaCMwJmmve3S/tXOdWxUNYGScDcjUsQXVDmmX3Kg==", 1071 | "requires": { 1072 | "is": "3.2.1", 1073 | "validator": "9.4.1" 1074 | }, 1075 | "dependencies": { 1076 | "validator": { 1077 | "version": "9.4.1", 1078 | "resolved": "https://registry.npmjs.org/validator/-/validator-9.4.1.tgz", 1079 | "integrity": "sha512-YV5KjzvRmSyJ1ee/Dm5UED0G+1L4GZnLN3w6/T+zZm8scVua4sOhYKWTUrKa0H/tMiJyO9QLHMPN+9mB/aMunA==" 1080 | } 1081 | } 1082 | }, 1083 | "morgan": { 1084 | "version": "1.9.0", 1085 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.9.0.tgz", 1086 | "integrity": "sha1-0B+mxlhZt2/PMbPLU6OCGjEdgFE=", 1087 | "requires": { 1088 | "basic-auth": "2.0.0", 1089 | "debug": "2.6.9", 1090 | "depd": "1.1.1", 1091 | "on-finished": "2.3.0", 1092 | "on-headers": "1.0.1" 1093 | } 1094 | }, 1095 | "mpath": { 1096 | "version": "0.3.0", 1097 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.3.0.tgz", 1098 | "integrity": "sha1-elj3iem1/TyUUgY0FXlg8mvV70Q=" 1099 | }, 1100 | "mquery": { 1101 | "version": "3.0.0-rc0", 1102 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.0.0-rc0.tgz", 1103 | "integrity": "sha512-tEAVSvlmd22irKJ8Q/tyI0LKRv8cV3aEkQ/EHW391ktGRWDDlfcpZyq6GYqu8yXGoz2JkC4aMJdNGca19wU1NQ==", 1104 | "requires": { 1105 | "bluebird": "3.5.0", 1106 | "debug": "2.6.9", 1107 | "regexp-clone": "0.0.1", 1108 | "sliced": "0.0.5" 1109 | }, 1110 | "dependencies": { 1111 | "bluebird": { 1112 | "version": "3.5.0", 1113 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.0.tgz", 1114 | "integrity": "sha1-eRQg1/VR7qKJdFOop3ZT+WYG1nw=" 1115 | }, 1116 | "sliced": { 1117 | "version": "0.0.5", 1118 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-0.0.5.tgz", 1119 | "integrity": "sha1-XtwETKTrb3gW1Qui/GPiXY/kcH8=" 1120 | } 1121 | } 1122 | }, 1123 | "ms": { 1124 | "version": "2.0.0", 1125 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1126 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1127 | }, 1128 | "nan": { 1129 | "version": "2.6.2", 1130 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.6.2.tgz", 1131 | "integrity": "sha1-5P805slf37WuzAjeZZb0NgWn20U=" 1132 | }, 1133 | "negotiator": { 1134 | "version": "0.6.1", 1135 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1136 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 1137 | }, 1138 | "node-pre-gyp": { 1139 | "version": "0.6.36", 1140 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.6.36.tgz", 1141 | "integrity": "sha1-22BBEst04NR3VU6bUFsXq936t4Y=", 1142 | "requires": { 1143 | "mkdirp": "0.5.1", 1144 | "nopt": "4.0.1", 1145 | "npmlog": "4.1.2", 1146 | "rc": "1.2.2", 1147 | "request": "2.83.0", 1148 | "rimraf": "2.6.2", 1149 | "semver": "5.4.1", 1150 | "tar": "2.2.1", 1151 | "tar-pack": "3.4.0" 1152 | } 1153 | }, 1154 | "nopt": { 1155 | "version": "4.0.1", 1156 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", 1157 | "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", 1158 | "requires": { 1159 | "abbrev": "1.1.1", 1160 | "osenv": "0.1.4" 1161 | } 1162 | }, 1163 | "npmlog": { 1164 | "version": "4.1.2", 1165 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1166 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1167 | "requires": { 1168 | "are-we-there-yet": "1.1.4", 1169 | "console-control-strings": "1.1.0", 1170 | "gauge": "2.7.4", 1171 | "set-blocking": "2.0.0" 1172 | } 1173 | }, 1174 | "number-is-nan": { 1175 | "version": "1.0.1", 1176 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1177 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1178 | }, 1179 | "oauth-sign": { 1180 | "version": "0.8.2", 1181 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", 1182 | "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=" 1183 | }, 1184 | "object-assign": { 1185 | "version": "4.1.1", 1186 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1187 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1188 | }, 1189 | "on-finished": { 1190 | "version": "2.3.0", 1191 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1192 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1193 | "requires": { 1194 | "ee-first": "1.1.1" 1195 | } 1196 | }, 1197 | "on-headers": { 1198 | "version": "1.0.1", 1199 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.1.tgz", 1200 | "integrity": "sha1-ko9dD0cNSTQmUepnlLCFfBAGk/c=" 1201 | }, 1202 | "once": { 1203 | "version": "1.4.0", 1204 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1205 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1206 | "requires": { 1207 | "wrappy": "1.0.2" 1208 | } 1209 | }, 1210 | "optimist": { 1211 | "version": "0.3.7", 1212 | "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.3.7.tgz", 1213 | "integrity": "sha1-yQlBrVnkJzMokjB00s8ufLxuwNk=", 1214 | "requires": { 1215 | "wordwrap": "0.0.3" 1216 | } 1217 | }, 1218 | "os-homedir": { 1219 | "version": "1.0.2", 1220 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1221 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1222 | }, 1223 | "os-tmpdir": { 1224 | "version": "1.0.2", 1225 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1226 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1227 | }, 1228 | "osenv": { 1229 | "version": "0.1.4", 1230 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.4.tgz", 1231 | "integrity": "sha1-Qv5tWVPfBsgGS+bxdsPQWqqjRkQ=", 1232 | "requires": { 1233 | "os-homedir": "1.0.2", 1234 | "os-tmpdir": "1.0.2" 1235 | } 1236 | }, 1237 | "parse-error": { 1238 | "version": "0.2.0", 1239 | "resolved": "https://registry.npmjs.org/parse-error/-/parse-error-0.2.0.tgz", 1240 | "integrity": "sha1-ojbVB2y+GWwVeBuJKyDQtpdZ/1s=" 1241 | }, 1242 | "parseurl": { 1243 | "version": "1.3.2", 1244 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 1245 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 1246 | }, 1247 | "passport": { 1248 | "version": "0.4.0", 1249 | "resolved": "https://registry.npmjs.org/passport/-/passport-0.4.0.tgz", 1250 | "integrity": "sha1-xQlWkTR71a07XhgCOMORTRbwWBE=", 1251 | "requires": { 1252 | "passport-strategy": "1.0.0", 1253 | "pause": "0.0.1" 1254 | } 1255 | }, 1256 | "passport-jwt": { 1257 | "version": "3.0.0", 1258 | "resolved": "https://registry.npmjs.org/passport-jwt/-/passport-jwt-3.0.0.tgz", 1259 | "integrity": "sha1-fZ5P8PoFIhCFQM4fz6g7vY+qKck=", 1260 | "requires": { 1261 | "jsonwebtoken": "7.4.3", 1262 | "passport-strategy": "1.0.0" 1263 | } 1264 | }, 1265 | "passport-strategy": { 1266 | "version": "1.0.0", 1267 | "resolved": "https://registry.npmjs.org/passport-strategy/-/passport-strategy-1.0.0.tgz", 1268 | "integrity": "sha1-tVOaqPwiWj0a0XlHbd8ja0QPUuQ=" 1269 | }, 1270 | "path-is-absolute": { 1271 | "version": "1.0.1", 1272 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1273 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1274 | }, 1275 | "path-to-regexp": { 1276 | "version": "0.1.7", 1277 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1278 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1279 | }, 1280 | "pause": { 1281 | "version": "0.0.1", 1282 | "resolved": "https://registry.npmjs.org/pause/-/pause-0.0.1.tgz", 1283 | "integrity": "sha1-HUCLP9t2kjuVQ9lvtMnf1TXZy10=" 1284 | }, 1285 | "performance-now": { 1286 | "version": "2.1.0", 1287 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1288 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 1289 | }, 1290 | "process-nextick-args": { 1291 | "version": "1.0.7", 1292 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 1293 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" 1294 | }, 1295 | "promise": { 1296 | "version": "6.1.0", 1297 | "resolved": "https://registry.npmjs.org/promise/-/promise-6.1.0.tgz", 1298 | "integrity": "sha1-LOcp9rlLRcJoka0GAsXJDgTG7vY=", 1299 | "requires": { 1300 | "asap": "1.0.0" 1301 | } 1302 | }, 1303 | "proxy-addr": { 1304 | "version": "1.1.5", 1305 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.5.tgz", 1306 | "integrity": "sha1-ccDuOxAt4/IC87ZPYI0XP8uhqRg=", 1307 | "requires": { 1308 | "forwarded": "0.1.2", 1309 | "ipaddr.js": "1.4.0" 1310 | } 1311 | }, 1312 | "punycode": { 1313 | "version": "1.4.1", 1314 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1315 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 1316 | }, 1317 | "qs": { 1318 | "version": "6.5.1", 1319 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 1320 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 1321 | }, 1322 | "range-parser": { 1323 | "version": "1.2.0", 1324 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 1325 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 1326 | }, 1327 | "raw-body": { 1328 | "version": "2.3.2", 1329 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.2.tgz", 1330 | "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=", 1331 | "requires": { 1332 | "bytes": "3.0.0", 1333 | "http-errors": "1.6.2", 1334 | "iconv-lite": "0.4.19", 1335 | "unpipe": "1.0.0" 1336 | } 1337 | }, 1338 | "rc": { 1339 | "version": "1.2.2", 1340 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.2.tgz", 1341 | "integrity": "sha1-2M6ctX6NZNnHut2YdsfDTL48cHc=", 1342 | "requires": { 1343 | "deep-extend": "0.4.2", 1344 | "ini": "1.3.4", 1345 | "minimist": "1.2.0", 1346 | "strip-json-comments": "2.0.1" 1347 | }, 1348 | "dependencies": { 1349 | "minimist": { 1350 | "version": "1.2.0", 1351 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1352 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" 1353 | } 1354 | } 1355 | }, 1356 | "readable-stream": { 1357 | "version": "2.2.7", 1358 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz", 1359 | "integrity": "sha1-BwV6y+JGeyIELTb5jFrVBwVOlbE=", 1360 | "requires": { 1361 | "buffer-shims": "1.0.0", 1362 | "core-util-is": "1.0.2", 1363 | "inherits": "2.0.3", 1364 | "isarray": "1.0.0", 1365 | "process-nextick-args": "1.0.7", 1366 | "string_decoder": "1.0.3", 1367 | "util-deprecate": "1.0.2" 1368 | } 1369 | }, 1370 | "regexp-clone": { 1371 | "version": "0.0.1", 1372 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-0.0.1.tgz", 1373 | "integrity": "sha1-p8LgmJH9vzj7sQ03b7cwA+aKxYk=" 1374 | }, 1375 | "repeat-string": { 1376 | "version": "1.6.1", 1377 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 1378 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" 1379 | }, 1380 | "request": { 1381 | "version": "2.83.0", 1382 | "resolved": "https://registry.npmjs.org/request/-/request-2.83.0.tgz", 1383 | "integrity": "sha512-lR3gD69osqm6EYLk9wB/G1W/laGWjzH90t1vEa2xuxHD5KUrSzp9pUSfTm+YC5Nxt2T8nMPEvKlhbQayU7bgFw==", 1384 | "requires": { 1385 | "aws-sign2": "0.7.0", 1386 | "aws4": "1.6.0", 1387 | "caseless": "0.12.0", 1388 | "combined-stream": "1.0.5", 1389 | "extend": "3.0.1", 1390 | "forever-agent": "0.6.1", 1391 | "form-data": "2.3.1", 1392 | "har-validator": "5.0.3", 1393 | "hawk": "6.0.2", 1394 | "http-signature": "1.2.0", 1395 | "is-typedarray": "1.0.0", 1396 | "isstream": "0.1.2", 1397 | "json-stringify-safe": "5.0.1", 1398 | "mime-types": "2.1.17", 1399 | "oauth-sign": "0.8.2", 1400 | "performance-now": "2.1.0", 1401 | "qs": "6.5.1", 1402 | "safe-buffer": "5.1.1", 1403 | "stringstream": "0.0.5", 1404 | "tough-cookie": "2.3.3", 1405 | "tunnel-agent": "0.6.0", 1406 | "uuid": "3.1.0" 1407 | } 1408 | }, 1409 | "require_optional": { 1410 | "version": "1.0.1", 1411 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1412 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1413 | "requires": { 1414 | "resolve-from": "2.0.0", 1415 | "semver": "5.4.1" 1416 | } 1417 | }, 1418 | "resolve-from": { 1419 | "version": "2.0.0", 1420 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1421 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 1422 | }, 1423 | "right-align": { 1424 | "version": "0.1.3", 1425 | "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", 1426 | "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", 1427 | "requires": { 1428 | "align-text": "0.1.4" 1429 | } 1430 | }, 1431 | "rimraf": { 1432 | "version": "2.6.2", 1433 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 1434 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 1435 | "requires": { 1436 | "glob": "7.1.2" 1437 | } 1438 | }, 1439 | "safe-buffer": { 1440 | "version": "5.1.1", 1441 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 1442 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 1443 | }, 1444 | "semver": { 1445 | "version": "5.4.1", 1446 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", 1447 | "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==" 1448 | }, 1449 | "send": { 1450 | "version": "0.15.6", 1451 | "resolved": "https://registry.npmjs.org/send/-/send-0.15.6.tgz", 1452 | "integrity": "sha1-IPI6nJJbdiq4JwX+L52yUqzkfjQ=", 1453 | "requires": { 1454 | "debug": "2.6.9", 1455 | "depd": "1.1.1", 1456 | "destroy": "1.0.4", 1457 | "encodeurl": "1.0.1", 1458 | "escape-html": "1.0.3", 1459 | "etag": "1.8.1", 1460 | "fresh": "0.5.2", 1461 | "http-errors": "1.6.2", 1462 | "mime": "1.3.4", 1463 | "ms": "2.0.0", 1464 | "on-finished": "2.3.0", 1465 | "range-parser": "1.2.0", 1466 | "statuses": "1.3.1" 1467 | }, 1468 | "dependencies": { 1469 | "statuses": { 1470 | "version": "1.3.1", 1471 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 1472 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 1473 | } 1474 | } 1475 | }, 1476 | "serve-favicon": { 1477 | "version": "2.4.5", 1478 | "resolved": "https://registry.npmjs.org/serve-favicon/-/serve-favicon-2.4.5.tgz", 1479 | "integrity": "sha512-s7F8h2NrslMkG50KxvlGdj+ApSwaLex0vexuJ9iFf3GLTIp1ph/l1qZvRe9T9TJEYZgmq72ZwJ2VYiAEtChknw==", 1480 | "requires": { 1481 | "etag": "1.8.1", 1482 | "fresh": "0.5.2", 1483 | "ms": "2.0.0", 1484 | "parseurl": "1.3.2", 1485 | "safe-buffer": "5.1.1" 1486 | } 1487 | }, 1488 | "serve-static": { 1489 | "version": "1.12.6", 1490 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.12.6.tgz", 1491 | "integrity": "sha1-uXN3P2NEmTTaVOW+ul4x2fQhFXc=", 1492 | "requires": { 1493 | "encodeurl": "1.0.1", 1494 | "escape-html": "1.0.3", 1495 | "parseurl": "1.3.2", 1496 | "send": "0.15.6" 1497 | } 1498 | }, 1499 | "set-blocking": { 1500 | "version": "2.0.0", 1501 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1502 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1503 | }, 1504 | "setprototypeof": { 1505 | "version": "1.0.3", 1506 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 1507 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 1508 | }, 1509 | "signal-exit": { 1510 | "version": "3.0.2", 1511 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1512 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 1513 | }, 1514 | "sliced": { 1515 | "version": "1.0.1", 1516 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 1517 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 1518 | }, 1519 | "sntp": { 1520 | "version": "2.0.2", 1521 | "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.0.2.tgz", 1522 | "integrity": "sha1-UGQRDwr4X3z9t9a2ekACjOUrSys=", 1523 | "requires": { 1524 | "hoek": "4.2.0" 1525 | } 1526 | }, 1527 | "source-map": { 1528 | "version": "0.4.4", 1529 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", 1530 | "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", 1531 | "requires": { 1532 | "amdefine": "1.0.1" 1533 | } 1534 | }, 1535 | "sshpk": { 1536 | "version": "1.13.1", 1537 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", 1538 | "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", 1539 | "requires": { 1540 | "asn1": "0.2.3", 1541 | "assert-plus": "1.0.0", 1542 | "bcrypt-pbkdf": "1.0.1", 1543 | "dashdash": "1.14.1", 1544 | "ecc-jsbn": "0.1.1", 1545 | "getpass": "0.1.7", 1546 | "jsbn": "0.1.1", 1547 | "tweetnacl": "0.14.5" 1548 | } 1549 | }, 1550 | "statuses": { 1551 | "version": "1.4.0", 1552 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 1553 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 1554 | }, 1555 | "string-width": { 1556 | "version": "1.0.2", 1557 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1558 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1559 | "requires": { 1560 | "code-point-at": "1.1.0", 1561 | "is-fullwidth-code-point": "1.0.0", 1562 | "strip-ansi": "3.0.1" 1563 | } 1564 | }, 1565 | "string_decoder": { 1566 | "version": "1.0.3", 1567 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 1568 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 1569 | "requires": { 1570 | "safe-buffer": "5.1.1" 1571 | } 1572 | }, 1573 | "stringstream": { 1574 | "version": "0.0.5", 1575 | "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", 1576 | "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=" 1577 | }, 1578 | "strip-ansi": { 1579 | "version": "3.0.1", 1580 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1581 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1582 | "requires": { 1583 | "ansi-regex": "2.1.1" 1584 | } 1585 | }, 1586 | "strip-json-comments": { 1587 | "version": "2.0.1", 1588 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1589 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 1590 | }, 1591 | "tar": { 1592 | "version": "2.2.1", 1593 | "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", 1594 | "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", 1595 | "requires": { 1596 | "block-stream": "0.0.9", 1597 | "fstream": "1.0.11", 1598 | "inherits": "2.0.3" 1599 | } 1600 | }, 1601 | "tar-pack": { 1602 | "version": "3.4.0", 1603 | "resolved": "https://registry.npmjs.org/tar-pack/-/tar-pack-3.4.0.tgz", 1604 | "integrity": "sha1-I74tf2cagzk3bL2wuP4/3r8xeYQ=", 1605 | "requires": { 1606 | "debug": "2.6.9", 1607 | "fstream": "1.0.11", 1608 | "fstream-ignore": "1.0.5", 1609 | "once": "1.4.0", 1610 | "readable-stream": "2.2.7", 1611 | "rimraf": "2.6.2", 1612 | "tar": "2.2.1", 1613 | "uid-number": "0.0.6" 1614 | } 1615 | }, 1616 | "topo": { 1617 | "version": "1.1.0", 1618 | "resolved": "https://registry.npmjs.org/topo/-/topo-1.1.0.tgz", 1619 | "integrity": "sha1-6ddRYV0buH3IZdsYL6HKCl71NtU=", 1620 | "requires": { 1621 | "hoek": "2.16.3" 1622 | }, 1623 | "dependencies": { 1624 | "hoek": { 1625 | "version": "2.16.3", 1626 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", 1627 | "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=" 1628 | } 1629 | } 1630 | }, 1631 | "tough-cookie": { 1632 | "version": "2.3.3", 1633 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.3.tgz", 1634 | "integrity": "sha1-C2GKVWW23qkL80JdBNVe3EdadWE=", 1635 | "requires": { 1636 | "punycode": "1.4.1" 1637 | } 1638 | }, 1639 | "transformers": { 1640 | "version": "2.1.0", 1641 | "resolved": "https://registry.npmjs.org/transformers/-/transformers-2.1.0.tgz", 1642 | "integrity": "sha1-XSPLNVYd2F3Gf7hIIwm0fVPM6ac=", 1643 | "requires": { 1644 | "css": "1.0.8", 1645 | "promise": "2.0.0", 1646 | "uglify-js": "2.2.5" 1647 | }, 1648 | "dependencies": { 1649 | "is-promise": { 1650 | "version": "1.0.1", 1651 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-1.0.1.tgz", 1652 | "integrity": "sha1-MVc3YcBX4zwukaq56W2gjO++duU=" 1653 | }, 1654 | "promise": { 1655 | "version": "2.0.0", 1656 | "resolved": "https://registry.npmjs.org/promise/-/promise-2.0.0.tgz", 1657 | "integrity": "sha1-RmSKqdYFr10ucMMCS/WUNtoCuA4=", 1658 | "requires": { 1659 | "is-promise": "1.0.1" 1660 | } 1661 | }, 1662 | "source-map": { 1663 | "version": "0.1.43", 1664 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.43.tgz", 1665 | "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", 1666 | "requires": { 1667 | "amdefine": "1.0.1" 1668 | } 1669 | }, 1670 | "uglify-js": { 1671 | "version": "2.2.5", 1672 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.2.5.tgz", 1673 | "integrity": "sha1-puAqcNg5eSuXgEiLe4sYTAlcmcc=", 1674 | "requires": { 1675 | "optimist": "0.3.7", 1676 | "source-map": "0.1.43" 1677 | } 1678 | } 1679 | } 1680 | }, 1681 | "tunnel-agent": { 1682 | "version": "0.6.0", 1683 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1684 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1685 | "requires": { 1686 | "safe-buffer": "5.1.1" 1687 | } 1688 | }, 1689 | "tweetnacl": { 1690 | "version": "0.14.5", 1691 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1692 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1693 | "optional": true 1694 | }, 1695 | "type-is": { 1696 | "version": "1.6.15", 1697 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz", 1698 | "integrity": "sha1-yrEPtJCeRByChC6v4a1kbIGARBA=", 1699 | "requires": { 1700 | "media-typer": "0.3.0", 1701 | "mime-types": "2.1.17" 1702 | } 1703 | }, 1704 | "uglify-js": { 1705 | "version": "2.8.29", 1706 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", 1707 | "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", 1708 | "requires": { 1709 | "source-map": "0.5.7", 1710 | "uglify-to-browserify": "1.0.2", 1711 | "yargs": "3.10.0" 1712 | }, 1713 | "dependencies": { 1714 | "source-map": { 1715 | "version": "0.5.7", 1716 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 1717 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" 1718 | } 1719 | } 1720 | }, 1721 | "uglify-to-browserify": { 1722 | "version": "1.0.2", 1723 | "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", 1724 | "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", 1725 | "optional": true 1726 | }, 1727 | "uid-number": { 1728 | "version": "0.0.6", 1729 | "resolved": "https://registry.npmjs.org/uid-number/-/uid-number-0.0.6.tgz", 1730 | "integrity": "sha1-DqEOgDXo61uOREnwbaHHMGY7qoE=" 1731 | }, 1732 | "unpipe": { 1733 | "version": "1.0.0", 1734 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1735 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1736 | }, 1737 | "util-deprecate": { 1738 | "version": "1.0.2", 1739 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1740 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1741 | }, 1742 | "utils-merge": { 1743 | "version": "1.0.0", 1744 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", 1745 | "integrity": "sha1-ApT7kiu5N1FTVBxPcJYjHyh8ivg=" 1746 | }, 1747 | "uuid": { 1748 | "version": "3.1.0", 1749 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 1750 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 1751 | }, 1752 | "validator": { 1753 | "version": "9.2.0", 1754 | "resolved": "https://registry.npmjs.org/validator/-/validator-9.2.0.tgz", 1755 | "integrity": "sha512-6Ij4Eo0KM4LkR0d0IegOwluG5453uqT5QyF5SV5Ezvm8/zmkKI/L4eoraafZGlZPC9guLkwKzgypcw8VGWWnGA==" 1756 | }, 1757 | "vary": { 1758 | "version": "1.1.2", 1759 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1760 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1761 | }, 1762 | "verror": { 1763 | "version": "1.10.0", 1764 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1765 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1766 | "requires": { 1767 | "assert-plus": "1.0.0", 1768 | "core-util-is": "1.0.2", 1769 | "extsprintf": "1.3.0" 1770 | } 1771 | }, 1772 | "void-elements": { 1773 | "version": "2.0.1", 1774 | "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-2.0.1.tgz", 1775 | "integrity": "sha1-wGavtYK7HLQSjWDqkjkulNXp2+w=" 1776 | }, 1777 | "wide-align": { 1778 | "version": "1.1.2", 1779 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.2.tgz", 1780 | "integrity": "sha512-ijDLlyQ7s6x1JgCLur53osjm/UXUYD9+0PbYKrBsYisYXzCxN+HC3mYDNy/dWdmf3AwqwU3CXwDCvsNgGK1S0w==", 1781 | "requires": { 1782 | "string-width": "1.0.2" 1783 | } 1784 | }, 1785 | "window-size": { 1786 | "version": "0.1.0", 1787 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz", 1788 | "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=" 1789 | }, 1790 | "with": { 1791 | "version": "4.0.3", 1792 | "resolved": "https://registry.npmjs.org/with/-/with-4.0.3.tgz", 1793 | "integrity": "sha1-7v0VTp550sjTQXtkeo8U2f7M4U4=", 1794 | "requires": { 1795 | "acorn": "1.2.2", 1796 | "acorn-globals": "1.0.9" 1797 | }, 1798 | "dependencies": { 1799 | "acorn": { 1800 | "version": "1.2.2", 1801 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-1.2.2.tgz", 1802 | "integrity": "sha1-yM4n3grMdtiW0rH6099YjZ6C8BQ=" 1803 | } 1804 | } 1805 | }, 1806 | "wordwrap": { 1807 | "version": "0.0.3", 1808 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", 1809 | "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=" 1810 | }, 1811 | "wrappy": { 1812 | "version": "1.0.2", 1813 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1814 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1815 | }, 1816 | "xtend": { 1817 | "version": "4.0.1", 1818 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 1819 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" 1820 | }, 1821 | "yargs": { 1822 | "version": "3.10.0", 1823 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz", 1824 | "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", 1825 | "requires": { 1826 | "camelcase": "1.2.1", 1827 | "cliui": "2.1.0", 1828 | "decamelize": "1.2.0", 1829 | "window-size": "0.1.0" 1830 | } 1831 | } 1832 | } 1833 | } 1834 | -------------------------------------------------------------------------------- /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 | "mongoose": "^5.0.1", 20 | "mongoose-validator": "^2.0.2", 21 | "morgan": "~1.9.0", 22 | "parse-error": "^0.2.0", 23 | "passport": "^0.4.0", 24 | "passport-jwt": "^3.0.0", 25 | "serve-favicon": "~2.4.5", 26 | "validator": "^9.2.0" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /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_mongo/059aa915fac77b1004c72d77aba180c65e0d27e9/public/v1/documentation/dist/favicon-16x16.png -------------------------------------------------------------------------------- /public/v1/documentation/dist/favicon-32x32.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/brianschardt/node_rest_api_mongo/059aa915fac77b1004c72d77aba180c65e0d27e9/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 | router.post( '/users', UserController.create); // C 21 | router.get( '/users', passport.authenticate('jwt', {session:false}), UserController.get); // R 22 | router.put( '/users', passport.authenticate('jwt', {session:false}), UserController.update); // U 23 | router.delete( '/users', passport.authenticate('jwt', {session:false}), UserController.remove); // D 24 | router.post( '/users/login', UserController.login); 25 | 26 | router.post( '/companies', passport.authenticate('jwt', {session:false}), CompanyController.create); // C 27 | router.get( '/companies', passport.authenticate('jwt', {session:false}), CompanyController.getAll); // R 28 | 29 | router.get( '/companies/:company_id', passport.authenticate('jwt', {session:false}), custom.company, CompanyController.get); // R 30 | router.put( '/companies/:company_id', passport.authenticate('jwt', {session:false}), custom.company, CompanyController.update); // U 31 | router.delete( '/companies/:company_id', passport.authenticate('jwt', {session:false}), custom.company, CompanyController.remove); // D 32 | 33 | router.get('/dash', passport.authenticate('jwt', {session:false}),HomeController.Dashboard) 34 | 35 | 36 | //********* API DOCUMENTATION ********** 37 | router.use('/docs/api.json', express.static(path.join(__dirname, '/../public/v1/documentation/api.json'))); 38 | router.use('/docs', express.static(path.join(__dirname, '/../public/v1/documentation/dist'))); 39 | module.exports = router; 40 | -------------------------------------------------------------------------------- /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 function(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({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({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 | --------------------------------------------------------------------------------