├── .dockerignore ├── .env.example ├── .github ├── dependabot.yml └── workflows │ └── nodejs.yml ├── .gitignore ├── .mergify.yml ├── CODE_OF_CONDUCT.md ├── CONTRIBUTING.md ├── Dockerfile ├── LICENSE ├── README.md ├── app.js ├── bin └── www ├── config.js ├── docker-compose.yml ├── lib ├── middleware.js └── notifier.js ├── models ├── property.js ├── reservation.js └── user.js ├── package-lock.json ├── package.json ├── public ├── images │ ├── airtng-logo.png │ ├── spock.png │ └── tngbg.jpg └── stylesheets │ ├── app.css │ ├── main.css │ ├── properties.css │ └── scaffolds.css ├── routes ├── index.js ├── properties.js ├── reservations.js ├── sessions.js └── users.js ├── spec ├── db-handler.js ├── home.spec.js ├── properties.spec.js ├── reservations.spec.js ├── sessions.spec.js └── users.spec.js ├── views ├── error.pug ├── index.pug ├── layout.pug ├── login.pug ├── properties │ ├── edit.pug │ ├── index.pug │ ├── new.pug │ └── show.pug └── users │ └── new.pug └── webhook.png /.dockerignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | npm-debug.log 3 | -------------------------------------------------------------------------------- /.env.example: -------------------------------------------------------------------------------- 1 | TWILIO_ACCOUNT_SID=Your-Account-SID 2 | TWILIO_AUTH_TOKEN=Your-Twilio-Auth-Token 3 | TWILIO_NUMBER=Your-Twilio-Phone-Number 4 | -------------------------------------------------------------------------------- /.github/dependabot.yml: -------------------------------------------------------------------------------- 1 | version: 2 2 | updates: 3 | - package-ecosystem: npm 4 | directory: "/" 5 | schedule: 6 | interval: daily 7 | open-pull-requests-limit: 10 8 | ignore: 9 | - dependency-name: mongoose 10 | versions: 11 | - 5.11.14 12 | - 5.11.15 13 | - 5.11.16 14 | - 5.11.17 15 | - 5.11.18 16 | - 5.11.19 17 | - 5.12.0 18 | - 5.12.1 19 | - 5.12.2 20 | - 5.12.3 21 | - 5.12.5 22 | - dependency-name: y18n 23 | versions: 24 | - 4.0.1 25 | - 4.0.2 26 | - dependency-name: mocha 27 | versions: 28 | - 8.2.1 29 | - 8.3.0 30 | - 8.3.1 31 | - dependency-name: mongodb-memory-server 32 | versions: 33 | - 6.9.3 34 | - dependency-name: twilio 35 | versions: 36 | - 3.51.0 37 | - dependency-name: lodash 38 | versions: 39 | - 4.17.20 40 | - dependency-name: pug 41 | versions: 42 | - 3.0.0 43 | -------------------------------------------------------------------------------- /.github/workflows/nodejs.yml: -------------------------------------------------------------------------------- 1 | # This workflow will do a clean install of node dependencies, build the source code and run tests across different versions of node 2 | # For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions 3 | 4 | name: Node.js 5 | 6 | on: 7 | push: 8 | branches: [ main ] 9 | pull_request: 10 | branches: [ main ] 11 | 12 | jobs: 13 | build: 14 | runs-on: ${{ matrix.platform }} 15 | strategy: 16 | matrix: 17 | node-version: [10.x, 12.x] 18 | platform: [windows-latest, macos-latest, ubuntu-latest] 19 | mongodb-version: [3.6] 20 | 21 | steps: 22 | - uses: actions/checkout@v1 23 | - name: Use Node.js ${{ matrix.node-version }} 24 | uses: actions/setup-node@v1 25 | with: 26 | node-version: ${{ matrix.node-version }} 27 | - run: npm ci 28 | - run: npm test 29 | env: 30 | CI: true 31 | TWILIO_ACCOUNT_SID: ACXXXXXX 32 | TWILIO_AUTH_TOKEN: XXXXX 33 | TWILIO_NUMBER: +1555555 34 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /log/*.log 2 | /tmp 3 | .DS_Store 4 | .idea/ 5 | .sass-cache 6 | *~ 7 | node_modules 8 | .env 9 | npm-debug.log 10 | .tool-versions 11 | -------------------------------------------------------------------------------- /.mergify.yml: -------------------------------------------------------------------------------- 1 | pull_request_rules: 2 | - name: automatic merge for Dependabot pull requests 3 | conditions: 4 | - author=dependabot-preview[bot] 5 | - status-success=build (10.x, macos-latest) 6 | - status-success=build (12.x, macos-latest) 7 | - status-success=build (10.x, windows-latest) 8 | - status-success=build (12.x, windows-latest) 9 | - status-success=build (10.x, ubuntu-latest) 10 | - status-success=build (12.x, ubuntu-latest) 11 | actions: 12 | merge: 13 | method: squash 14 | -------------------------------------------------------------------------------- /CODE_OF_CONDUCT.md: -------------------------------------------------------------------------------- 1 | # Contributor Covenant Code of Conduct 2 | 3 | ## Our Pledge 4 | 5 | In the interest of fostering an open and welcoming environment, we as 6 | contributors and maintainers pledge to making participation in our project and 7 | our community a harassment-free experience for everyone, regardless of age, body 8 | size, disability, ethnicity, sex characteristics, gender identity and expression, 9 | level of experience, education, socio-economic status, nationality, personal 10 | appearance, race, religion, or sexual identity and orientation. 11 | 12 | ## Our Standards 13 | 14 | Examples of behavior that contributes to creating a positive environment 15 | include: 16 | 17 | - Using welcoming and inclusive language 18 | - Being respectful of differing viewpoints and experiences 19 | - Gracefully accepting constructive criticism 20 | - Focusing on what is best for the community 21 | - Showing empathy towards other community members 22 | 23 | Examples of unacceptable behavior by participants include: 24 | 25 | - The use of sexualized language or imagery and unwelcome sexual attention or 26 | advances 27 | - Trolling, insulting/derogatory comments, and personal or political attacks 28 | - Public or private harassment 29 | - Publishing others' private information, such as a physical or electronic 30 | address, without explicit permission 31 | - Other conduct which could reasonably be considered inappropriate in a 32 | professional setting 33 | 34 | ## Our Responsibilities 35 | 36 | Project maintainers are responsible for clarifying the standards of acceptable 37 | behavior and are expected to take appropriate and fair corrective action in 38 | response to any instances of unacceptable behavior. 39 | 40 | Project maintainers have the right and responsibility to remove, edit, or 41 | reject comments, commits, code, wiki edits, issues, and other contributions 42 | that are not aligned to this Code of Conduct, or to ban temporarily or 43 | permanently any contributor for other behaviors that they deem inappropriate, 44 | threatening, offensive, or harmful. 45 | 46 | ## Scope 47 | 48 | This Code of Conduct applies both within project spaces and in public spaces 49 | when an individual is representing the project or its community. Examples of 50 | representing a project or community include using an official project e-mail 51 | address, posting via an official social media account, or acting as an appointed 52 | representative at an online or offline event. Representation of a project may be 53 | further defined and clarified by project maintainers. 54 | 55 | ## Enforcement 56 | 57 | Instances of abusive, harassing, or otherwise unacceptable behavior may be 58 | reported by contacting the project team at open-source@twilio.com. All 59 | complaints will be reviewed and investigated and will result in a response that 60 | is deemed necessary and appropriate to the circumstances. The project team is 61 | obligated to maintain confidentiality with regard to the reporter of an incident. 62 | Further details of specific enforcement policies may be posted separately. 63 | 64 | Project maintainers who do not follow or enforce the Code of Conduct in good 65 | faith may face temporary or permanent repercussions as determined by other 66 | members of the project's leadership. 67 | 68 | ## Attribution 69 | 70 | This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, 71 | available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html 72 | 73 | [homepage]: https://www.contributor-covenant.org 74 | -------------------------------------------------------------------------------- /CONTRIBUTING.md: -------------------------------------------------------------------------------- 1 | # Contributing to Twilio 2 | 3 | All third party contributors acknowledge that any contributions they provide will be made under the same open source license that the open source project is provided under. 4 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:10 2 | 3 | WORKDIR /usr/src/app 4 | 5 | COPY package*.json ./ 6 | 7 | RUN npm install 8 | 9 | COPY . . 10 | 11 | EXPOSE 3000 12 | 13 | CMD [ "npm", "start" ] 14 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 Twilio Inc. 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 | 2 | Twilio 3 | 4 | 5 | # AirTNG App: Part 1 - Workflow Automation with Twilio with Node.js and Express 6 | > This template is part of Twilio CodeExchange. If you encounter any issues with this code, please open an issue at [github.com/twilio-labs/code-exchange/issues](https://github.com/twilio-labs/code-exchange/issues). 7 | 8 | 9 | ![](https://github.com/TwilioDevEd/airtng-node/workflows/Node.js/badge.svg) 10 | 11 | ## About 12 | 13 | Learn how to automate your workflow using Twilio's REST API and Twilio SMS. This example app is a vacation rental site, where the host can confirm a reservation via SMS. 14 | 15 | [Read the full tutorial here](https://www.twilio.com/docs/tutorials/walkthrough/workflow-automation/node/express)! 16 | 17 | Implementations in other languages: 18 | 19 | | .NET | Java | Python | PHP | Ruby | 20 | | :--- | :--- | :----- | :-- | :--- | 21 | | [Done](https://github.com/TwilioDevEd/airtng-csharp) | [Done](https://github.com/TwilioDevEd/airtng-servlets) | [Done](https://github.com/TwilioDevEd/airtng-flask) | [Done](https://github.com/TwilioDevEd/airtng-laravel) | [Done](TBD) | 22 | 23 | ## Set up 24 | 25 | ### Requirements 26 | 27 | - [Nodejs](https://nodejs.org/) v10 or v12 28 | - [Mongo](https://docs.mongodb.com/manual/installation/) 29 | 30 | ### Twilio Account Settings 31 | 32 | This application should give you a ready-made starting point for writing your own application. 33 | Before we begin, we need to collect all the config values we need to run the application: 34 | 35 | | Config Value | Description | 36 | | :---------- | :---------- | 37 | | TWILIO_ACCOUNT_SID and TWILIO_AUTH_TOKEN | You could find them in your [Twilio Account Settings](https://www.twilio.com/console/account/settings)| 38 | | TWILIO_NUMBER | You can get one [here](https://www.twilio.com/console/phone-numbers/incoming) | 39 | 40 | ### Local Development 41 | 42 | 1. Clone this repository and `cd` into it. 43 | 44 | ```bash 45 | git clone git@github.com:TwilioDevEd/airtng-node.git 46 | cd airtng-node 47 | ``` 48 | 49 | 2. Install the dependencies. 50 | 51 | ```bash 52 | npm install 53 | ``` 54 | 55 | 3. Copy the sample configuration `.env.example` to `.env`, and then edit `.env` to match your configuration. 56 | 57 | ```bash 58 | cp .env.example .env 59 | ``` 60 | 61 | See [Twilio Account Settings](#twilio-account-settings) to locate the necessary environment variables. The phone numbers should be in [E.164 format](https://www.twilio.com/help/faq/phone-numbers/how-do-i-format-phone-numbers-to-work-internationally). 62 | 63 | 4. Run the application (will run on port 3000). 64 | 65 | ```bash 66 | npm start 67 | ``` 68 | 69 | 5. Check it out at [http://localhost:3000](http://localhost:3000) 70 | 71 | 6. To let our Twilio Phone number use the callback endpoint we exposed, our development server will need to be publicly accessible. You could expose the application to the wider Internet using [ngrok](https://ngrok.com/). [Here](https://www.twilio.com/blog/2015/09/6-awesome-reasons-to-use-ngrok-when-testing-webhooks.html) there is an interesting article about why we recommend you to use ngrok. 72 | 73 | ```bash 74 | ngrok http 3000 75 | ``` 76 | 77 | Keep in mind that our endpoint is: 78 | 79 | ``` 80 | http://.ngrok.io/reservations/handle 81 | ``` 82 | 83 | 7. You will need to configure Twilio to send requests to your application when SMS are received. You will need to provision at least one Twilio number with sms capabilities so the application's users can make property reservations. On [Twilio Account Settings](#twilio-account-settings) you could find the link to buy a Twilio number. Once you have a number you need to configure your number to work with your application. Open the number management page and open a number's configuration by clicking on it. Remember that the number where you change the SMS webhook must be the same one you set on the TwilioPhoneNumber setting. 84 | 85 | ![Configure Messaging](webhook.png) 86 | 87 | That's it! 88 | 89 | ### Docker 90 | 91 | If you have [Docker](https://www.docker.com/) already installed on your machine, you can use our `docker-compose.yml` to setup your project. 92 | 93 | 1. Make sure you have the project cloned. 94 | 2. Setup the `.env` file as outlined in the [Local Development](#local-development) steps. 95 | 3. Run `docker-compose up`. 96 | 4. Follow the steps in [Local Development](#local-development) on how to expose your port to Twilio using a tool like [ngrok](https://ngrok.com/) and configure the remaining parts of your application. 97 | 98 | ### Tests 99 | 100 | You can run the tests locally by typing 101 | 102 | ```bash 103 | npm test 104 | ``` 105 | 106 | ### Resources 107 | 108 | - The CodeExchange repository can be found [here](https://github.com/twilio-labs/code-exchange/). 109 | 110 | ### Contributing 111 | 112 | This template is open source and welcomes contributions. All contributions are subject to our [Code of Conduct](https://github.com/twilio-labs/.github/blob/master/CODE_OF_CONDUCT.md). 113 | 114 | ### License 115 | 116 | [MIT](http://www.opensource.org/licenses/mit-license.html) 117 | 118 | ### Disclaimer 119 | 120 | No warranty expressed or implied. Software is as is. 121 | 122 | [twilio]: https://www.twilio.com 123 | -------------------------------------------------------------------------------- /app.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config(); 2 | 3 | var express = require('express'); 4 | var path = require('path'); 5 | var favicon = require('serve-favicon'); 6 | var logger = require('morgan'); 7 | var cookieParser = require('cookie-parser'); 8 | var bodyParser = require('body-parser'); 9 | var flash = require('connect-flash'); 10 | var mongoose = require('mongoose'); 11 | 12 | var passport = require('passport'); 13 | var LocalStrategy = require('passport-local').Strategy; 14 | 15 | var routes = require('./routes/index'); 16 | var users = require('./routes/users'); 17 | var sessions = require('./routes/sessions'); 18 | var properties = require('./routes/properties'); 19 | var reservations = require('./routes/reservations'); 20 | 21 | var app = express(); 22 | 23 | // view engine setup 24 | app.set('views', path.join(__dirname, 'views')); 25 | app.set('view engine', 'pug'); 26 | 27 | // uncomment after placing your favicon in /public 28 | //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); 29 | app.use(logger('dev')); 30 | app.use(bodyParser.json()); 31 | app.use(bodyParser.urlencoded({ extended: false })); 32 | app.use(cookieParser()); 33 | app.use(require('express-session')({ 34 | secret: 'keyboard cat', 35 | resave: false, 36 | saveUninitialized: false 37 | })); 38 | app.use(passport.initialize()); 39 | app.use(passport.session()); 40 | app.use(express.static(path.join(__dirname, 'public'))); 41 | app.use(flash()); 42 | 43 | app.use('/', routes); 44 | app.use('/users', users); 45 | app.use('/properties', properties); 46 | app.use('/reservations', reservations); 47 | app.use('/sessions', sessions); 48 | 49 | var User = require('./models/user'); 50 | passport.use(new LocalStrategy(User.authenticate())); 51 | passport.serializeUser(User.serializeUser()); 52 | passport.deserializeUser(User.deserializeUser()); 53 | 54 | 55 | // catch 404 and forward to error handler 56 | app.use(function(req, res, next) { 57 | var err = new Error('Not Found'); 58 | err.status = 404; 59 | next(err); 60 | }); 61 | 62 | // error handlers 63 | 64 | // development error handler 65 | // will print stacktrace 66 | if (app.get('env') === 'development') { 67 | app.use(function(err, req, res, next) { 68 | res.status(err.status || 500); 69 | res.render('error', { 70 | message: err.message, 71 | error: err 72 | }); 73 | }); 74 | } 75 | 76 | // production error handler 77 | // no stacktraces leaked to user 78 | app.use(function(err, req, res, next) { 79 | res.status(err.status || 500); 80 | res.render('error', { 81 | message: err.message, 82 | error: {} 83 | }); 84 | }); 85 | 86 | 87 | module.exports = app; 88 | -------------------------------------------------------------------------------- /bin/www: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | /** 4 | * Module dependencies. 5 | */ 6 | 7 | var app = require('../app'); 8 | var debug = require('debug')('airtng-node:server'); 9 | var http = require('http'); 10 | var mongoose = require('mongoose'); 11 | 12 | /** 13 | * Get port from environment and store in Express. 14 | */ 15 | 16 | var port = normalizePort(process.env.PORT || '3000'); 17 | app.set('port', port); 18 | 19 | /** 20 | * Create HTTP server. 21 | */ 22 | 23 | var server = http.createServer(app); 24 | 25 | /** 26 | * Listen on provided port, on all network interfaces. 27 | */ 28 | 29 | server.listen(port); 30 | server.on('error', onError); 31 | server.on('listening', onListening); 32 | 33 | /** 34 | * Normalize a port into a number, string, or false. 35 | */ 36 | 37 | function normalizePort(val) { 38 | var port = parseInt(val, 10); 39 | 40 | if (isNaN(port)) { 41 | // named pipe 42 | return val; 43 | } 44 | 45 | if (port >= 0) { 46 | // port number 47 | return port; 48 | } 49 | 50 | return false; 51 | } 52 | 53 | /** 54 | * Event listener for HTTP server "error" event. 55 | */ 56 | 57 | function onError(error) { 58 | if (error.syscall !== 'listen') { 59 | throw error; 60 | } 61 | 62 | var bind = typeof port === 'string' 63 | ? 'Pipe ' + port 64 | : 'Port ' + port; 65 | 66 | // handle specific listen errors with friendly messages 67 | switch (error.code) { 68 | case 'EACCES': 69 | console.error(bind + ' requires elevated privileges'); 70 | process.exit(1); 71 | break; 72 | case 'EADDRINUSE': 73 | console.error(bind + ' is already in use'); 74 | process.exit(1); 75 | break; 76 | default: 77 | throw error; 78 | } 79 | } 80 | 81 | /** 82 | * Event listener for HTTP server "listening" event. 83 | */ 84 | 85 | function onListening() { 86 | var addr = server.address(); 87 | var bind = typeof addr === 'string' 88 | ? 'pipe ' + addr 89 | : 'port ' + addr.port; 90 | debug('Listening on ' + bind); 91 | } 92 | 93 | /** 94 | * Initialize database connection. 95 | */ 96 | 97 | var mongoConnection = process.env.DOCKER_MONGO || "localhost" 98 | 99 | mongoose.connect('mongodb://' + mongoConnection + '/airtng', { 100 | useNewUrlParser: true, 101 | useUnifiedTopology: true 102 | }); 103 | mongoose.set('useUnifiedTopology', true); 104 | mongoose.Promise = Promise; 105 | -------------------------------------------------------------------------------- /config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | accountSid: process.env.TWILIO_ACCOUNT_SID, 3 | authToken: process.env.TWILIO_AUTH_TOKEN, 4 | phoneNumber: process.env.TWILIO_NUMBER 5 | }; 6 | -------------------------------------------------------------------------------- /docker-compose.yml: -------------------------------------------------------------------------------- 1 | version: "3.8" 2 | services: 3 | app: 4 | container_name: app 5 | restart: always 6 | build: . 7 | environment: 8 | - DOCKER_MONGO=mongo 9 | ports: 10 | - "3000:3000" 11 | links: 12 | - mongo 13 | mongo: 14 | container_name: mongo 15 | image: mongo:4.2 16 | ports: 17 | - "27018:27017" 18 | -------------------------------------------------------------------------------- /lib/middleware.js: -------------------------------------------------------------------------------- 1 | exports.isAuthenticated = function (req, res, next) { 2 | if (req.isAuthenticated()) { 3 | return next(); 4 | } 5 | 6 | res.redirect('/sessions/login'); 7 | } 8 | -------------------------------------------------------------------------------- /lib/notifier.js: -------------------------------------------------------------------------------- 1 | var config = require('../config'); 2 | var client = require('twilio')(config.accountSid, config.authToken); 3 | var Reservation = require('../models/reservation'); 4 | 5 | var sendNotification = function() { 6 | Reservation.find({status: 'pending'}) 7 | .deepPopulate('property property.owner guest') 8 | .then(function (reservations) { 9 | if (reservations.length > 1) { 10 | return; 11 | } 12 | 13 | var reservation = reservations[0]; 14 | var owner = reservation.property.owner; 15 | 16 | // Send the notification 17 | client.messages.create({ 18 | to: phoneNumber(owner), 19 | from: config.phoneNumber, 20 | body: buildMessage(reservation) 21 | }) 22 | .then(function(res) { 23 | console.log(res.body); 24 | }) 25 | .catch(function(err) { 26 | console.log(err); 27 | }); 28 | }); 29 | }; 30 | 31 | var phoneNumber = function(owner) { 32 | return "+" + owner.countryCode + owner.phoneNumber; 33 | }; 34 | 35 | var buildMessage = function(reservation) { 36 | var message = "You have a new reservation request from " + reservation.guest.username + 37 | " for " + reservation.property.description + ":\n" + 38 | reservation.message + "\n" + 39 | "Reply accept or reject"; 40 | 41 | return message; 42 | }; 43 | 44 | exports.sendNotification = sendNotification; 45 | -------------------------------------------------------------------------------- /models/property.js: -------------------------------------------------------------------------------- 1 | var mongoose = require('mongoose'); 2 | 3 | var propertySchema = new mongoose.Schema({ 4 | description: { type: String, required: true }, 5 | imageUrl: { type: String, required: true }, 6 | date: { type: Date, default: Date.now }, 7 | owner: { 8 | type: mongoose.Schema.Types.ObjectId, 9 | ref: 'user' 10 | } 11 | }); 12 | 13 | var property = mongoose.model('property', propertySchema); 14 | 15 | module.exports = property; 16 | -------------------------------------------------------------------------------- /models/reservation.js: -------------------------------------------------------------------------------- 1 | var mongoose = require('mongoose'); 2 | var deepPopulate = require('mongoose-deep-populate')(mongoose); 3 | 4 | var reservationSchema = new mongoose.Schema({ 5 | message: { type: String, required: true }, 6 | status: { type: String, default: 'pending' }, 7 | date: { type: Date, default: Date.now }, 8 | property: { 9 | type: mongoose.Schema.Types.ObjectId, 10 | ref: 'property' 11 | }, 12 | guest: { 13 | type: mongoose.Schema.Types.ObjectId, 14 | ref: 'user' 15 | } 16 | }); 17 | 18 | reservationSchema.plugin(deepPopulate, {}); 19 | 20 | var reservation = mongoose.model('reservation', reservationSchema); 21 | 22 | module.exports = reservation; 23 | -------------------------------------------------------------------------------- /models/user.js: -------------------------------------------------------------------------------- 1 | var mongoose = require('mongoose'); 2 | var passportLocalMongoose = require('passport-local-mongoose'); 3 | 4 | var userSchema = new mongoose.Schema({ 5 | email: { type: String, required: true }, 6 | username: { type: String, required: true }, 7 | password: { type: String }, 8 | countryCode: { type: String, required: true }, 9 | phoneNumber: { type: String, required: true }, 10 | date: { type: Date, default: Date.now }, 11 | }); 12 | 13 | userSchema.plugin(passportLocalMongoose); 14 | 15 | var user = mongoose.model('user', userSchema); 16 | 17 | module.exports = user; 18 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "airtng-node", 3 | "version": "0.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/babel-types": { 8 | "version": "7.0.7", 9 | "resolved": "https://registry.npmjs.org/@types/babel-types/-/babel-types-7.0.7.tgz", 10 | "integrity": "sha512-dBtBbrc+qTHy1WdfHYjBwRln4+LWqASWakLHsWHR2NWHIFkv4W3O070IGoGLEBrJBvct3r0L1BUPuvURi7kYUQ==" 11 | }, 12 | "@types/babylon": { 13 | "version": "6.16.5", 14 | "resolved": "https://registry.npmjs.org/@types/babylon/-/babylon-6.16.5.tgz", 15 | "integrity": "sha512-xH2e58elpj1X4ynnKp9qSnWlsRTIs6n3tgLGNfwAGHwePw0mulHQllV34n0T25uYSu1k0hRKkWXF890B1yS47w==", 16 | "requires": { 17 | "@types/babel-types": "*" 18 | } 19 | }, 20 | "@types/body-parser": { 21 | "version": "1.19.0", 22 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.0.tgz", 23 | "integrity": "sha512-W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ==", 24 | "requires": { 25 | "@types/connect": "*", 26 | "@types/node": "*" 27 | } 28 | }, 29 | "@types/connect": { 30 | "version": "3.4.33", 31 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.33.tgz", 32 | "integrity": "sha512-2+FrkXY4zllzTNfJth7jOqEHC+enpLeGslEhpnTAkg21GkRrWV4SsAtqchtT4YS9/nODBU2/ZfsBY2X4J/dX7A==", 33 | "requires": { 34 | "@types/node": "*" 35 | } 36 | }, 37 | "@types/cross-spawn": { 38 | "version": "6.0.2", 39 | "resolved": "https://registry.npmjs.org/@types/cross-spawn/-/cross-spawn-6.0.2.tgz", 40 | "integrity": "sha512-KuwNhp3eza+Rhu8IFI5HUXRP0LIhqH5cAjubUvGXXthh4YYBuP2ntwEX+Cz8GJoZUHlKo247wPWOfA9LYEq4cw==", 41 | "dev": true, 42 | "requires": { 43 | "@types/node": "*" 44 | } 45 | }, 46 | "@types/debug": { 47 | "version": "4.1.5", 48 | "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.5.tgz", 49 | "integrity": "sha512-Q1y515GcOdTHgagaVFhHnIFQ38ygs/kmxdNpvpou+raI9UO3YZcHDngBSYKQklcKlvA7iuQlmIKbzvmxcOE9CQ==", 50 | "dev": true 51 | }, 52 | "@types/dedent": { 53 | "version": "0.7.0", 54 | "resolved": "https://registry.npmjs.org/@types/dedent/-/dedent-0.7.0.tgz", 55 | "integrity": "sha512-EGlKlgMhnLt/cM4DbUSafFdrkeJoC9Mvnj0PUCU7tFmTjMjNRT957kXCx0wYm3JuEq4o4ZsS5vG+NlkM2DMd2A==", 56 | "dev": true 57 | }, 58 | "@types/express": { 59 | "version": "4.17.3", 60 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.3.tgz", 61 | "integrity": "sha512-I8cGRJj3pyOLs/HndoP+25vOqhqWkAZsWMEmq1qXy/b/M3ppufecUwaK2/TVDVxcV61/iSdhykUjQQ2DLSrTdg==", 62 | "requires": { 63 | "@types/body-parser": "*", 64 | "@types/express-serve-static-core": "*", 65 | "@types/serve-static": "*" 66 | } 67 | }, 68 | "@types/express-serve-static-core": { 69 | "version": "4.17.2", 70 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.2.tgz", 71 | "integrity": "sha512-El9yMpctM6tORDAiBwZVLMcxoTMcqqRO9dVyYcn7ycLWbvR8klrDn8CAOwRfZujZtWD7yS/mshTdz43jMOejbg==", 72 | "requires": { 73 | "@types/node": "*", 74 | "@types/range-parser": "*" 75 | } 76 | }, 77 | "@types/find-cache-dir": { 78 | "version": "3.2.0", 79 | "resolved": "https://registry.npmjs.org/@types/find-cache-dir/-/find-cache-dir-3.2.0.tgz", 80 | "integrity": "sha512-+JeT9qb2Jwzw72WdjU+TSvD5O1QRPWCeRpDJV+guiIq+2hwR0DFGw+nZNbTFjMIVe6Bf4GgAKeB/6Ytx6+MbeQ==", 81 | "dev": true 82 | }, 83 | "@types/find-package-json": { 84 | "version": "1.1.1", 85 | "resolved": "https://registry.npmjs.org/@types/find-package-json/-/find-package-json-1.1.1.tgz", 86 | "integrity": "sha512-XMCocYkg6VUpkbOQMKa3M5cgc3MvU/LJKQwd3VUJrWZbLr2ARUggupsCAF8DxjEEIuSO6HlnH+vl+XV4bgVeEQ==", 87 | "dev": true, 88 | "requires": { 89 | "@types/node": "*" 90 | } 91 | }, 92 | "@types/get-port": { 93 | "version": "4.2.0", 94 | "resolved": "https://registry.npmjs.org/@types/get-port/-/get-port-4.2.0.tgz", 95 | "integrity": "sha512-Iv2FAb5RnIk/eFO2CTu8k+0VMmIR15pKbcqRWi+s3ydW+aKXlN2yemP92SrO++ERyJx+p6Ie1ggbLBMbU1SjiQ==", 96 | "dev": true, 97 | "requires": { 98 | "get-port": "*" 99 | } 100 | }, 101 | "@types/lockfile": { 102 | "version": "1.0.1", 103 | "resolved": "https://registry.npmjs.org/@types/lockfile/-/lockfile-1.0.1.tgz", 104 | "integrity": "sha512-65WZedEm4AnOsBDdsapJJG42MhROu3n4aSSiu87JXF/pSdlubxZxp3S1yz3kTfkJ2KBPud4CpjoHVAptOm9Zmw==", 105 | "dev": true 106 | }, 107 | "@types/md5-file": { 108 | "version": "4.0.2", 109 | "resolved": "https://registry.npmjs.org/@types/md5-file/-/md5-file-4.0.2.tgz", 110 | "integrity": "sha512-8gacRfEqLrmZ6KofpFfxyjsm/LYepeWUWUJGaf5A9W9J5B2/dRZMdkDqFDL6YDa9IweH12IO76jO7mpsK2B3wg==", 111 | "dev": true 112 | }, 113 | "@types/mime": { 114 | "version": "2.0.1", 115 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-2.0.1.tgz", 116 | "integrity": "sha512-FwI9gX75FgVBJ7ywgnq/P7tw+/o1GUbtP0KzbtusLigAOgIgNISRK0ZPl4qertvXSIE8YbsVJueQ90cDt9YYyw==" 117 | }, 118 | "@types/mkdirp": { 119 | "version": "1.0.1", 120 | "resolved": "https://registry.npmjs.org/@types/mkdirp/-/mkdirp-1.0.1.tgz", 121 | "integrity": "sha512-HkGSK7CGAXncr8Qn/0VqNtExEE+PHMWb+qlR1faHMao7ng6P3tAaoWWBMdva0gL5h4zprjIO89GJOLXsMcDm1Q==", 122 | "dev": true, 123 | "requires": { 124 | "@types/node": "*" 125 | } 126 | }, 127 | "@types/node": { 128 | "version": "13.9.2", 129 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.9.2.tgz", 130 | "integrity": "sha512-bnoqK579sAYrQbp73wwglccjJ4sfRdKU7WNEZ5FW4K2U6Kc0/eZ5kvXG0JKsEKFB50zrFmfFt52/cvBbZa7eXg==" 131 | }, 132 | "@types/range-parser": { 133 | "version": "1.2.3", 134 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.3.tgz", 135 | "integrity": "sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA==" 136 | }, 137 | "@types/serve-static": { 138 | "version": "1.13.3", 139 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.3.tgz", 140 | "integrity": "sha512-oprSwp094zOglVrXdlo/4bAHtKTAxX6VT8FOZlBKrmyLbNvE1zxZyJ6yikMVtHIvwP45+ZQGJn+FdXGKTozq0g==", 141 | "requires": { 142 | "@types/express-serve-static-core": "*", 143 | "@types/mime": "*" 144 | } 145 | }, 146 | "@types/tmp": { 147 | "version": "0.1.0", 148 | "resolved": "https://registry.npmjs.org/@types/tmp/-/tmp-0.1.0.tgz", 149 | "integrity": "sha512-6IwZ9HzWbCq6XoQWhxLpDjuADodH/MKXRUIDFudvgjcVdjFknvmR+DNsoUeer4XPrEnrZs04Jj+kfV9pFsrhmA==", 150 | "dev": true 151 | }, 152 | "@types/uuid": { 153 | "version": "7.0.0", 154 | "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-7.0.0.tgz", 155 | "integrity": "sha512-RiX1I0lK9WFLFqy2xOxke396f0wKIzk5sAll0tL4J4XDYJXURI7JOs96XQb3nP+2gEpQ/LutBb66jgiT5oQshQ==", 156 | "dev": true 157 | }, 158 | "accepts": { 159 | "version": "1.3.7", 160 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 161 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 162 | "requires": { 163 | "mime-types": "~2.1.24", 164 | "negotiator": "0.6.2" 165 | } 166 | }, 167 | "agent-base": { 168 | "version": "6.0.0", 169 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.0.tgz", 170 | "integrity": "sha512-j1Q7cSCqN+AwrmDd+pzgqc0/NpC655x2bUf5ZjRIO77DcNBFmh+OgRNzF6OKdCC9RSCb19fGd99+bhXFdkRNqw==", 171 | "dev": true, 172 | "requires": { 173 | "debug": "4" 174 | } 175 | }, 176 | "align-text": { 177 | "version": "0.1.4", 178 | "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", 179 | "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", 180 | "requires": { 181 | "kind-of": "^3.0.2", 182 | "longest": "^1.0.1", 183 | "repeat-string": "^1.5.2" 184 | } 185 | }, 186 | "ansi-colors": { 187 | "version": "3.2.3", 188 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 189 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 190 | "dev": true 191 | }, 192 | "ansi-regex": { 193 | "version": "3.0.0", 194 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 195 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 196 | }, 197 | "ansi-styles": { 198 | "version": "3.2.1", 199 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 200 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 201 | "dev": true, 202 | "requires": { 203 | "color-convert": "^1.9.0" 204 | } 205 | }, 206 | "anymatch": { 207 | "version": "3.1.1", 208 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 209 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 210 | "dev": true, 211 | "requires": { 212 | "normalize-path": "^3.0.0", 213 | "picomatch": "^2.0.4" 214 | } 215 | }, 216 | "aproba": { 217 | "version": "1.2.0", 218 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 219 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 220 | }, 221 | "are-we-there-yet": { 222 | "version": "1.1.5", 223 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 224 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 225 | "requires": { 226 | "delegates": "^1.0.0", 227 | "readable-stream": "^2.0.6" 228 | } 229 | }, 230 | "argparse": { 231 | "version": "1.0.10", 232 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 233 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 234 | "dev": true, 235 | "requires": { 236 | "sprintf-js": "~1.0.2" 237 | } 238 | }, 239 | "array-flatten": { 240 | "version": "1.1.1", 241 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 242 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 243 | }, 244 | "assertion-error": { 245 | "version": "1.1.0", 246 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 247 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 248 | "dev": true 249 | }, 250 | "asynckit": { 251 | "version": "0.4.0", 252 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 253 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 254 | "dev": true 255 | }, 256 | "axios": { 257 | "version": "0.19.2", 258 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.19.2.tgz", 259 | "integrity": "sha512-fjgm5MvRHLhx+osE2xoekY70AhARk3a6hkN+3Io1jc00jtquGvxYlKlsFUhmUET0V5te6CcZI7lcv2Ym61mjHA==", 260 | "requires": { 261 | "follow-redirects": "1.5.10" 262 | } 263 | }, 264 | "babel-runtime": { 265 | "version": "6.26.0", 266 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", 267 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", 268 | "requires": { 269 | "core-js": "^2.4.0", 270 | "regenerator-runtime": "^0.11.0" 271 | } 272 | }, 273 | "babel-types": { 274 | "version": "6.26.0", 275 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz", 276 | "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=", 277 | "requires": { 278 | "babel-runtime": "^6.26.0", 279 | "esutils": "^2.0.2", 280 | "lodash": "^4.17.4", 281 | "to-fast-properties": "^1.0.3" 282 | } 283 | }, 284 | "babylon": { 285 | "version": "6.18.0", 286 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", 287 | "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==" 288 | }, 289 | "balanced-match": { 290 | "version": "1.0.0", 291 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 292 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 293 | "dev": true 294 | }, 295 | "base64-js": { 296 | "version": "1.3.1", 297 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", 298 | "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==" 299 | }, 300 | "basic-auth": { 301 | "version": "2.0.1", 302 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 303 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 304 | "requires": { 305 | "safe-buffer": "5.1.2" 306 | }, 307 | "dependencies": { 308 | "safe-buffer": { 309 | "version": "5.1.2", 310 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 311 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 312 | } 313 | } 314 | }, 315 | "binary-extensions": { 316 | "version": "2.0.0", 317 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.0.0.tgz", 318 | "integrity": "sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow==", 319 | "dev": true 320 | }, 321 | "bindings": { 322 | "version": "1.5.0", 323 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", 324 | "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", 325 | "requires": { 326 | "file-uri-to-path": "1.0.0" 327 | } 328 | }, 329 | "bl": { 330 | "version": "2.2.0", 331 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.0.tgz", 332 | "integrity": "sha512-wbgvOpqopSr7uq6fJrLH8EsvYMJf9gzfo2jCsL2eTy75qXPukA4pCgHamOQkZtY5vmfVtjB+P3LNlMHW5CEZXA==", 333 | "requires": { 334 | "readable-stream": "^2.3.5", 335 | "safe-buffer": "^5.1.1" 336 | } 337 | }, 338 | "bluebird": { 339 | "version": "3.5.1", 340 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 341 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 342 | }, 343 | "body-parser": { 344 | "version": "1.19.0", 345 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 346 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 347 | "requires": { 348 | "bytes": "3.1.0", 349 | "content-type": "~1.0.4", 350 | "debug": "2.6.9", 351 | "depd": "~1.1.2", 352 | "http-errors": "1.7.2", 353 | "iconv-lite": "0.4.24", 354 | "on-finished": "~2.3.0", 355 | "qs": "6.7.0", 356 | "raw-body": "2.4.0", 357 | "type-is": "~1.6.17" 358 | }, 359 | "dependencies": { 360 | "debug": { 361 | "version": "2.6.9", 362 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 363 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 364 | "requires": { 365 | "ms": "2.0.0" 366 | } 367 | }, 368 | "ms": { 369 | "version": "2.0.0", 370 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 371 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 372 | } 373 | } 374 | }, 375 | "brace-expansion": { 376 | "version": "1.1.11", 377 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 378 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 379 | "dev": true, 380 | "requires": { 381 | "balanced-match": "^1.0.0", 382 | "concat-map": "0.0.1" 383 | } 384 | }, 385 | "braces": { 386 | "version": "3.0.2", 387 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 388 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 389 | "dev": true, 390 | "requires": { 391 | "fill-range": "^7.0.1" 392 | } 393 | }, 394 | "browser-stdout": { 395 | "version": "1.3.1", 396 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 397 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 398 | "dev": true 399 | }, 400 | "bson": { 401 | "version": "1.1.3", 402 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.3.tgz", 403 | "integrity": "sha512-TdiJxMVnodVS7r0BdL42y/pqC9cL2iKynVwA0Ho3qbsQYr428veL3l7BQyuqiw+Q5SqqoT0m4srSY/BlZ9AxXg==" 404 | }, 405 | "buffer": { 406 | "version": "5.5.0", 407 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.5.0.tgz", 408 | "integrity": "sha512-9FTEDjLjwoAkEwyMGDjYJQN2gfRgOKBKRfiglhvibGbpeeU/pQn1bJxQqm32OD/AIeEuHxU9roxXxg34Byp/Ww==", 409 | "requires": { 410 | "base64-js": "^1.0.2", 411 | "ieee754": "^1.1.4" 412 | } 413 | }, 414 | "buffer-crc32": { 415 | "version": "0.2.13", 416 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 417 | "integrity": "sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=", 418 | "dev": true 419 | }, 420 | "buffer-equal-constant-time": { 421 | "version": "1.0.1", 422 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 423 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 424 | }, 425 | "bytes": { 426 | "version": "3.1.0", 427 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 428 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 429 | }, 430 | "camelcase": { 431 | "version": "1.2.1", 432 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", 433 | "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=" 434 | }, 435 | "center-align": { 436 | "version": "0.1.3", 437 | "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", 438 | "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", 439 | "requires": { 440 | "align-text": "^0.1.3", 441 | "lazy-cache": "^1.0.3" 442 | } 443 | }, 444 | "chai": { 445 | "version": "3.5.0", 446 | "resolved": "https://registry.npmjs.org/chai/-/chai-3.5.0.tgz", 447 | "integrity": "sha1-TQJjewZ/6Vi9v906QOxW/vc3Mkc=", 448 | "dev": true, 449 | "requires": { 450 | "assertion-error": "^1.0.1", 451 | "deep-eql": "^0.1.3", 452 | "type-detect": "^1.0.0" 453 | } 454 | }, 455 | "chalk": { 456 | "version": "2.4.2", 457 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 458 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 459 | "dev": true, 460 | "requires": { 461 | "ansi-styles": "^3.2.1", 462 | "escape-string-regexp": "^1.0.5", 463 | "supports-color": "^5.3.0" 464 | }, 465 | "dependencies": { 466 | "supports-color": { 467 | "version": "5.5.0", 468 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 469 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 470 | "dev": true, 471 | "requires": { 472 | "has-flag": "^3.0.0" 473 | } 474 | } 475 | } 476 | }, 477 | "chokidar": { 478 | "version": "3.3.0", 479 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.0.tgz", 480 | "integrity": "sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A==", 481 | "dev": true, 482 | "requires": { 483 | "anymatch": "~3.1.1", 484 | "braces": "~3.0.2", 485 | "fsevents": "~2.1.1", 486 | "glob-parent": "~5.1.0", 487 | "is-binary-path": "~2.1.0", 488 | "is-glob": "~4.0.1", 489 | "normalize-path": "~3.0.0", 490 | "readdirp": "~3.2.0" 491 | } 492 | }, 493 | "chownr": { 494 | "version": "1.1.4", 495 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 496 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==" 497 | }, 498 | "cliui": { 499 | "version": "2.1.0", 500 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", 501 | "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", 502 | "requires": { 503 | "center-align": "^0.1.1", 504 | "right-align": "^0.1.1", 505 | "wordwrap": "0.0.2" 506 | }, 507 | "dependencies": { 508 | "wordwrap": { 509 | "version": "0.0.2", 510 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", 511 | "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=" 512 | } 513 | } 514 | }, 515 | "code-point-at": { 516 | "version": "1.1.0", 517 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 518 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 519 | }, 520 | "color-convert": { 521 | "version": "1.9.3", 522 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 523 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 524 | "dev": true, 525 | "requires": { 526 | "color-name": "1.1.3" 527 | } 528 | }, 529 | "color-name": { 530 | "version": "1.1.3", 531 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 532 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 533 | "dev": true 534 | }, 535 | "combined-stream": { 536 | "version": "1.0.8", 537 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 538 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 539 | "dev": true, 540 | "requires": { 541 | "delayed-stream": "~1.0.0" 542 | } 543 | }, 544 | "commondir": { 545 | "version": "1.0.1", 546 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 547 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 548 | "dev": true 549 | }, 550 | "component-emitter": { 551 | "version": "1.3.0", 552 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 553 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", 554 | "dev": true 555 | }, 556 | "concat-map": { 557 | "version": "0.0.1", 558 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 559 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 560 | "dev": true 561 | }, 562 | "connect-flash": { 563 | "version": "0.1.1", 564 | "resolved": "https://registry.npmjs.org/connect-flash/-/connect-flash-0.1.1.tgz", 565 | "integrity": "sha1-2GMPJtlaf4UfmVax6MxnMvO2qjA=" 566 | }, 567 | "console-control-strings": { 568 | "version": "1.1.0", 569 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 570 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 571 | }, 572 | "constantinople": { 573 | "version": "3.1.2", 574 | "resolved": "https://registry.npmjs.org/constantinople/-/constantinople-3.1.2.tgz", 575 | "integrity": "sha512-yePcBqEFhLOqSBtwYOGGS1exHo/s1xjekXiinh4itpNQGCu4KA1euPh1fg07N2wMITZXQkBz75Ntdt1ctGZouw==", 576 | "requires": { 577 | "@types/babel-types": "^7.0.0", 578 | "@types/babylon": "^6.16.2", 579 | "babel-types": "^6.26.0", 580 | "babylon": "^6.18.0" 581 | } 582 | }, 583 | "content-disposition": { 584 | "version": "0.5.3", 585 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 586 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 587 | "requires": { 588 | "safe-buffer": "5.1.2" 589 | }, 590 | "dependencies": { 591 | "safe-buffer": { 592 | "version": "5.1.2", 593 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 594 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 595 | } 596 | } 597 | }, 598 | "content-type": { 599 | "version": "1.0.4", 600 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 601 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 602 | }, 603 | "cookie": { 604 | "version": "0.1.3", 605 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.1.3.tgz", 606 | "integrity": "sha1-5zSlwUF/zkctWu+Cw4HKu2TRpDU=" 607 | }, 608 | "cookie-parser": { 609 | "version": "1.3.5", 610 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.3.5.tgz", 611 | "integrity": "sha1-nXVVcPtdF4kHcSJ6AjFNm+fPg1Y=", 612 | "requires": { 613 | "cookie": "0.1.3", 614 | "cookie-signature": "1.0.6" 615 | } 616 | }, 617 | "cookie-signature": { 618 | "version": "1.0.6", 619 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 620 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 621 | }, 622 | "cookiejar": { 623 | "version": "2.1.2", 624 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.2.tgz", 625 | "integrity": "sha512-Mw+adcfzPxcPeI+0WlvRrr/3lGVO0bD75SxX6811cxSh1Wbxx7xZBGK1eVtDf6si8rg2lhnUjsVLMFMfbRIuwA==", 626 | "dev": true 627 | }, 628 | "core-js": { 629 | "version": "2.6.11", 630 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.11.tgz", 631 | "integrity": "sha512-5wjnpaT/3dV+XB4borEsnAYQchn00XSgTAWKDkEqv+K8KevjbzmofK6hfJ9TZIlpj2N0xQpazy7PiRQiWHqzWg==" 632 | }, 633 | "core-util-is": { 634 | "version": "1.0.2", 635 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 636 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 637 | }, 638 | "cross-spawn": { 639 | "version": "7.0.3", 640 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 641 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 642 | "dev": true, 643 | "requires": { 644 | "path-key": "^3.1.0", 645 | "shebang-command": "^2.0.0", 646 | "which": "^2.0.1" 647 | }, 648 | "dependencies": { 649 | "which": { 650 | "version": "2.0.2", 651 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 652 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 653 | "dev": true, 654 | "requires": { 655 | "isexe": "^2.0.0" 656 | } 657 | } 658 | } 659 | }, 660 | "dayjs": { 661 | "version": "1.8.23", 662 | "resolved": "https://registry.npmjs.org/dayjs/-/dayjs-1.8.23.tgz", 663 | "integrity": "sha512-NmYHMFONftoZbeOhVz6jfiXI4zSiPN6NoVWJgC0aZQfYVwzy/ZpESPHuCcI0B8BUMpSJQ08zenHDbofOLKq8hQ==" 664 | }, 665 | "debug": { 666 | "version": "4.1.1", 667 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 668 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 669 | "requires": { 670 | "ms": "^2.1.1" 671 | } 672 | }, 673 | "decamelize": { 674 | "version": "1.2.0", 675 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 676 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 677 | }, 678 | "decompress-response": { 679 | "version": "4.2.1", 680 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz", 681 | "integrity": "sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw==", 682 | "requires": { 683 | "mimic-response": "^2.0.0" 684 | } 685 | }, 686 | "dedent": { 687 | "version": "0.7.0", 688 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", 689 | "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", 690 | "dev": true 691 | }, 692 | "deep-eql": { 693 | "version": "0.1.3", 694 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-0.1.3.tgz", 695 | "integrity": "sha1-71WKyrjeJSBs1xOQbXTlaTDrafI=", 696 | "dev": true, 697 | "requires": { 698 | "type-detect": "0.1.1" 699 | }, 700 | "dependencies": { 701 | "type-detect": { 702 | "version": "0.1.1", 703 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-0.1.1.tgz", 704 | "integrity": "sha1-C6XsKohWQORw6k6FBZcZANrFiCI=", 705 | "dev": true 706 | } 707 | } 708 | }, 709 | "deep-extend": { 710 | "version": "0.6.0", 711 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 712 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 713 | }, 714 | "define-properties": { 715 | "version": "1.1.3", 716 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 717 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 718 | "dev": true, 719 | "requires": { 720 | "object-keys": "^1.0.12" 721 | } 722 | }, 723 | "delayed-stream": { 724 | "version": "1.0.0", 725 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 726 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 727 | "dev": true 728 | }, 729 | "delegates": { 730 | "version": "1.0.0", 731 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 732 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 733 | }, 734 | "denque": { 735 | "version": "1.4.1", 736 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.4.1.tgz", 737 | "integrity": "sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ==" 738 | }, 739 | "depd": { 740 | "version": "1.1.2", 741 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 742 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 743 | }, 744 | "destroy": { 745 | "version": "1.0.4", 746 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 747 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 748 | }, 749 | "detect-libc": { 750 | "version": "1.0.3", 751 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 752 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=" 753 | }, 754 | "diff": { 755 | "version": "3.5.0", 756 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 757 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 758 | "dev": true 759 | }, 760 | "doctypes": { 761 | "version": "1.1.0", 762 | "resolved": "https://registry.npmjs.org/doctypes/-/doctypes-1.1.0.tgz", 763 | "integrity": "sha1-6oCxBqh1OHdOijpKWv4pPeSJ4Kk=" 764 | }, 765 | "dotenv": { 766 | "version": "8.2.0", 767 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 768 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" 769 | }, 770 | "ecdsa-sig-formatter": { 771 | "version": "1.0.11", 772 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 773 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 774 | "requires": { 775 | "safe-buffer": "^5.0.1" 776 | } 777 | }, 778 | "ee-first": { 779 | "version": "1.1.1", 780 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 781 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 782 | }, 783 | "emoji-regex": { 784 | "version": "7.0.3", 785 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 786 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 787 | "dev": true 788 | }, 789 | "encodeurl": { 790 | "version": "1.0.2", 791 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 792 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 793 | }, 794 | "end-of-stream": { 795 | "version": "1.4.4", 796 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 797 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 798 | "requires": { 799 | "once": "^1.4.0" 800 | } 801 | }, 802 | "es-abstract": { 803 | "version": "1.17.4", 804 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.4.tgz", 805 | "integrity": "sha512-Ae3um/gb8F0mui/jPL+QiqmglkUsaQf7FwBEHYIFkztkneosu9imhqHpBzQ3h1vit8t5iQ74t6PEVvphBZiuiQ==", 806 | "dev": true, 807 | "requires": { 808 | "es-to-primitive": "^1.2.1", 809 | "function-bind": "^1.1.1", 810 | "has": "^1.0.3", 811 | "has-symbols": "^1.0.1", 812 | "is-callable": "^1.1.5", 813 | "is-regex": "^1.0.5", 814 | "object-inspect": "^1.7.0", 815 | "object-keys": "^1.1.1", 816 | "object.assign": "^4.1.0", 817 | "string.prototype.trimleft": "^2.1.1", 818 | "string.prototype.trimright": "^2.1.1" 819 | } 820 | }, 821 | "es-to-primitive": { 822 | "version": "1.2.1", 823 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 824 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 825 | "dev": true, 826 | "requires": { 827 | "is-callable": "^1.1.4", 828 | "is-date-object": "^1.0.1", 829 | "is-symbol": "^1.0.2" 830 | } 831 | }, 832 | "escape-html": { 833 | "version": "1.0.3", 834 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 835 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 836 | }, 837 | "escape-string-regexp": { 838 | "version": "1.0.5", 839 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 840 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 841 | "dev": true 842 | }, 843 | "esprima": { 844 | "version": "4.0.1", 845 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 846 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 847 | "dev": true 848 | }, 849 | "esutils": { 850 | "version": "2.0.3", 851 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 852 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==" 853 | }, 854 | "etag": { 855 | "version": "1.8.1", 856 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 857 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 858 | }, 859 | "expand-template": { 860 | "version": "2.0.3", 861 | "resolved": "https://registry.npmjs.org/expand-template/-/expand-template-2.0.3.tgz", 862 | "integrity": "sha512-XYfuKMvj4O35f/pOXLObndIRvyQ+/+6AhODh+OKWj9S9498pHHn/IMszH+gt0fBCRWMNfk1ZSp5x3AifmnI2vg==" 863 | }, 864 | "express": { 865 | "version": "4.17.1", 866 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 867 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 868 | "requires": { 869 | "accepts": "~1.3.7", 870 | "array-flatten": "1.1.1", 871 | "body-parser": "1.19.0", 872 | "content-disposition": "0.5.3", 873 | "content-type": "~1.0.4", 874 | "cookie": "0.4.0", 875 | "cookie-signature": "1.0.6", 876 | "debug": "2.6.9", 877 | "depd": "~1.1.2", 878 | "encodeurl": "~1.0.2", 879 | "escape-html": "~1.0.3", 880 | "etag": "~1.8.1", 881 | "finalhandler": "~1.1.2", 882 | "fresh": "0.5.2", 883 | "merge-descriptors": "1.0.1", 884 | "methods": "~1.1.2", 885 | "on-finished": "~2.3.0", 886 | "parseurl": "~1.3.3", 887 | "path-to-regexp": "0.1.7", 888 | "proxy-addr": "~2.0.5", 889 | "qs": "6.7.0", 890 | "range-parser": "~1.2.1", 891 | "safe-buffer": "5.1.2", 892 | "send": "0.17.1", 893 | "serve-static": "1.14.1", 894 | "setprototypeof": "1.1.1", 895 | "statuses": "~1.5.0", 896 | "type-is": "~1.6.18", 897 | "utils-merge": "1.0.1", 898 | "vary": "~1.1.2" 899 | }, 900 | "dependencies": { 901 | "cookie": { 902 | "version": "0.4.0", 903 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 904 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 905 | }, 906 | "debug": { 907 | "version": "2.6.9", 908 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 909 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 910 | "requires": { 911 | "ms": "2.0.0" 912 | } 913 | }, 914 | "ms": { 915 | "version": "2.0.0", 916 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 917 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 918 | }, 919 | "safe-buffer": { 920 | "version": "5.1.2", 921 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 922 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 923 | } 924 | } 925 | }, 926 | "express-session": { 927 | "version": "1.17.0", 928 | "resolved": "https://registry.npmjs.org/express-session/-/express-session-1.17.0.tgz", 929 | "integrity": "sha512-t4oX2z7uoSqATbMfsxWMbNjAL0T5zpvcJCk3Z9wnPPN7ibddhnmDZXHfEcoBMG2ojKXZoCyPMc5FbtK+G7SoDg==", 930 | "requires": { 931 | "cookie": "0.4.0", 932 | "cookie-signature": "1.0.6", 933 | "debug": "2.6.9", 934 | "depd": "~2.0.0", 935 | "on-headers": "~1.0.2", 936 | "parseurl": "~1.3.3", 937 | "safe-buffer": "5.2.0", 938 | "uid-safe": "~2.1.5" 939 | }, 940 | "dependencies": { 941 | "cookie": { 942 | "version": "0.4.0", 943 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 944 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 945 | }, 946 | "debug": { 947 | "version": "2.6.9", 948 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 949 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 950 | "requires": { 951 | "ms": "2.0.0" 952 | } 953 | }, 954 | "depd": { 955 | "version": "2.0.0", 956 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 957 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 958 | }, 959 | "ms": { 960 | "version": "2.0.0", 961 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 962 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 963 | } 964 | } 965 | }, 966 | "extend": { 967 | "version": "3.0.2", 968 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 969 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 970 | "dev": true 971 | }, 972 | "fd-slicer": { 973 | "version": "1.1.0", 974 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 975 | "integrity": "sha1-JcfInLH5B3+IkbvmHY85Dq4lbx4=", 976 | "dev": true, 977 | "requires": { 978 | "pend": "~1.2.0" 979 | } 980 | }, 981 | "file-uri-to-path": { 982 | "version": "1.0.0", 983 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", 984 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==" 985 | }, 986 | "fill-range": { 987 | "version": "7.0.1", 988 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 989 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 990 | "dev": true, 991 | "requires": { 992 | "to-regex-range": "^5.0.1" 993 | } 994 | }, 995 | "finalhandler": { 996 | "version": "1.1.2", 997 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 998 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 999 | "requires": { 1000 | "debug": "2.6.9", 1001 | "encodeurl": "~1.0.2", 1002 | "escape-html": "~1.0.3", 1003 | "on-finished": "~2.3.0", 1004 | "parseurl": "~1.3.3", 1005 | "statuses": "~1.5.0", 1006 | "unpipe": "~1.0.0" 1007 | }, 1008 | "dependencies": { 1009 | "debug": { 1010 | "version": "2.6.9", 1011 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1012 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1013 | "requires": { 1014 | "ms": "2.0.0" 1015 | } 1016 | }, 1017 | "ms": { 1018 | "version": "2.0.0", 1019 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1020 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1021 | } 1022 | } 1023 | }, 1024 | "find-cache-dir": { 1025 | "version": "3.3.1", 1026 | "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.1.tgz", 1027 | "integrity": "sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ==", 1028 | "dev": true, 1029 | "requires": { 1030 | "commondir": "^1.0.1", 1031 | "make-dir": "^3.0.2", 1032 | "pkg-dir": "^4.1.0" 1033 | } 1034 | }, 1035 | "find-package-json": { 1036 | "version": "1.2.0", 1037 | "resolved": "https://registry.npmjs.org/find-package-json/-/find-package-json-1.2.0.tgz", 1038 | "integrity": "sha512-+SOGcLGYDJHtyqHd87ysBhmaeQ95oWspDKnMXBrnQ9Eq4OkLNqejgoaD8xVWu6GPa0B6roa6KinCMEMcVeqONw==", 1039 | "dev": true 1040 | }, 1041 | "find-up": { 1042 | "version": "3.0.0", 1043 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 1044 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 1045 | "dev": true, 1046 | "requires": { 1047 | "locate-path": "^3.0.0" 1048 | } 1049 | }, 1050 | "flat": { 1051 | "version": "4.1.0", 1052 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 1053 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 1054 | "dev": true, 1055 | "requires": { 1056 | "is-buffer": "~2.0.3" 1057 | }, 1058 | "dependencies": { 1059 | "is-buffer": { 1060 | "version": "2.0.4", 1061 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1062 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1063 | "dev": true 1064 | } 1065 | } 1066 | }, 1067 | "follow-redirects": { 1068 | "version": "1.5.10", 1069 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.5.10.tgz", 1070 | "integrity": "sha512-0V5l4Cizzvqt5D44aTXbFZz+FtyXV1vrDN6qrelxtfYQKW0KO0W2T/hkE8xvGa/540LkZlkaUjO4ailYTFtHVQ==", 1071 | "requires": { 1072 | "debug": "=3.1.0" 1073 | }, 1074 | "dependencies": { 1075 | "debug": { 1076 | "version": "3.1.0", 1077 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1078 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1079 | "requires": { 1080 | "ms": "2.0.0" 1081 | } 1082 | }, 1083 | "ms": { 1084 | "version": "2.0.0", 1085 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1086 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1087 | } 1088 | } 1089 | }, 1090 | "form-data": { 1091 | "version": "2.5.1", 1092 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.5.1.tgz", 1093 | "integrity": "sha512-m21N3WOmEEURgk6B9GLOE4RuWOFf28Lhh9qGYeNlGq4VDXUlJy2th2slBNU8Gp8EzloYZOibZJ7t5ecIrFSjVA==", 1094 | "dev": true, 1095 | "requires": { 1096 | "asynckit": "^0.4.0", 1097 | "combined-stream": "^1.0.6", 1098 | "mime-types": "^2.1.12" 1099 | } 1100 | }, 1101 | "formidable": { 1102 | "version": "1.2.2", 1103 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.2.2.tgz", 1104 | "integrity": "sha512-V8gLm+41I/8kguQ4/o1D3RIHRmhYFG4pnNyonvua+40rqcEmT4+V71yaZ3B457xbbgCsCfjSPi65u/W6vK1U5Q==", 1105 | "dev": true 1106 | }, 1107 | "forwarded": { 1108 | "version": "0.1.2", 1109 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 1110 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 1111 | }, 1112 | "fresh": { 1113 | "version": "0.5.2", 1114 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1115 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 1116 | }, 1117 | "fs-constants": { 1118 | "version": "1.0.0", 1119 | "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", 1120 | "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==" 1121 | }, 1122 | "fs.realpath": { 1123 | "version": "1.0.0", 1124 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1125 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1126 | "dev": true 1127 | }, 1128 | "fsevents": { 1129 | "version": "2.1.2", 1130 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.2.tgz", 1131 | "integrity": "sha512-R4wDiBwZ0KzpgOWetKDug1FZcYhqYnUYKtfZYt4mD5SBz76q0KR4Q9o7GIPamsVPGmW3EYPPJ0dOOjvx32ldZA==", 1132 | "dev": true, 1133 | "optional": true 1134 | }, 1135 | "function-bind": { 1136 | "version": "1.1.1", 1137 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1138 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 1139 | }, 1140 | "gauge": { 1141 | "version": "2.7.4", 1142 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 1143 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 1144 | "requires": { 1145 | "aproba": "^1.0.3", 1146 | "console-control-strings": "^1.0.0", 1147 | "has-unicode": "^2.0.0", 1148 | "object-assign": "^4.1.0", 1149 | "signal-exit": "^3.0.0", 1150 | "string-width": "^1.0.1", 1151 | "strip-ansi": "^3.0.1", 1152 | "wide-align": "^1.1.0" 1153 | }, 1154 | "dependencies": { 1155 | "ansi-regex": { 1156 | "version": "2.1.1", 1157 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 1158 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 1159 | }, 1160 | "is-fullwidth-code-point": { 1161 | "version": "1.0.0", 1162 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1163 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1164 | "requires": { 1165 | "number-is-nan": "^1.0.0" 1166 | } 1167 | }, 1168 | "string-width": { 1169 | "version": "1.0.2", 1170 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1171 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1172 | "requires": { 1173 | "code-point-at": "^1.0.0", 1174 | "is-fullwidth-code-point": "^1.0.0", 1175 | "strip-ansi": "^3.0.0" 1176 | } 1177 | }, 1178 | "strip-ansi": { 1179 | "version": "3.0.1", 1180 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1181 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1182 | "requires": { 1183 | "ansi-regex": "^2.0.0" 1184 | } 1185 | } 1186 | } 1187 | }, 1188 | "generaterr": { 1189 | "version": "1.5.0", 1190 | "resolved": "https://registry.npmjs.org/generaterr/-/generaterr-1.5.0.tgz", 1191 | "integrity": "sha1-sM62zFFk3yoGEzjMNAqGFTlcUvw=" 1192 | }, 1193 | "get-caller-file": { 1194 | "version": "2.0.5", 1195 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1196 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1197 | "dev": true 1198 | }, 1199 | "get-port": { 1200 | "version": "5.1.1", 1201 | "resolved": "https://registry.npmjs.org/get-port/-/get-port-5.1.1.tgz", 1202 | "integrity": "sha512-g/Q1aTSDOxFpchXC4i8ZWvxA1lnPqx/JHqcpIw0/LX9T8x/GBbi6YnlN5nhaKIFkT8oFsscUKgDJYxfwfS6QsQ==", 1203 | "dev": true 1204 | }, 1205 | "github-from-package": { 1206 | "version": "0.0.0", 1207 | "resolved": "https://registry.npmjs.org/github-from-package/-/github-from-package-0.0.0.tgz", 1208 | "integrity": "sha1-l/tdlr/eiXMxPyDoKI75oWf6ZM4=" 1209 | }, 1210 | "glob": { 1211 | "version": "7.1.3", 1212 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1213 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1214 | "dev": true, 1215 | "requires": { 1216 | "fs.realpath": "^1.0.0", 1217 | "inflight": "^1.0.4", 1218 | "inherits": "2", 1219 | "minimatch": "^3.0.4", 1220 | "once": "^1.3.0", 1221 | "path-is-absolute": "^1.0.0" 1222 | } 1223 | }, 1224 | "glob-parent": { 1225 | "version": "5.1.0", 1226 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.0.tgz", 1227 | "integrity": "sha512-qjtRgnIVmOfnKUE3NJAQEdk+lKrxfw8t5ke7SXtfMTHcjsBfOfWXCQfdb30zfDoZQ2IRSIiidmjtbHZPZ++Ihw==", 1228 | "dev": true, 1229 | "requires": { 1230 | "is-glob": "^4.0.1" 1231 | } 1232 | }, 1233 | "growl": { 1234 | "version": "1.10.5", 1235 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1236 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1237 | "dev": true 1238 | }, 1239 | "has": { 1240 | "version": "1.0.3", 1241 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1242 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1243 | "requires": { 1244 | "function-bind": "^1.1.1" 1245 | } 1246 | }, 1247 | "has-flag": { 1248 | "version": "3.0.0", 1249 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1250 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1251 | "dev": true 1252 | }, 1253 | "has-symbols": { 1254 | "version": "1.0.1", 1255 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1256 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1257 | "dev": true 1258 | }, 1259 | "has-unicode": { 1260 | "version": "2.0.1", 1261 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 1262 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 1263 | }, 1264 | "he": { 1265 | "version": "1.2.0", 1266 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1267 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1268 | "dev": true 1269 | }, 1270 | "http-errors": { 1271 | "version": "1.7.2", 1272 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 1273 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 1274 | "requires": { 1275 | "depd": "~1.1.2", 1276 | "inherits": "2.0.3", 1277 | "setprototypeof": "1.1.1", 1278 | "statuses": ">= 1.5.0 < 2", 1279 | "toidentifier": "1.0.0" 1280 | }, 1281 | "dependencies": { 1282 | "inherits": { 1283 | "version": "2.0.3", 1284 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1285 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1286 | } 1287 | } 1288 | }, 1289 | "https-proxy-agent": { 1290 | "version": "5.0.0", 1291 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 1292 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 1293 | "dev": true, 1294 | "requires": { 1295 | "agent-base": "6", 1296 | "debug": "4" 1297 | } 1298 | }, 1299 | "iconv-lite": { 1300 | "version": "0.4.24", 1301 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1302 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1303 | "requires": { 1304 | "safer-buffer": ">= 2.1.2 < 3" 1305 | } 1306 | }, 1307 | "ieee754": { 1308 | "version": "1.1.13", 1309 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", 1310 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==" 1311 | }, 1312 | "inflight": { 1313 | "version": "1.0.6", 1314 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1315 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1316 | "dev": true, 1317 | "requires": { 1318 | "once": "^1.3.0", 1319 | "wrappy": "1" 1320 | } 1321 | }, 1322 | "inherits": { 1323 | "version": "2.0.4", 1324 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1325 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1326 | }, 1327 | "ini": { 1328 | "version": "1.3.5", 1329 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1330 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 1331 | }, 1332 | "ipaddr.js": { 1333 | "version": "1.9.1", 1334 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1335 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 1336 | }, 1337 | "is-binary-path": { 1338 | "version": "2.1.0", 1339 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1340 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1341 | "dev": true, 1342 | "requires": { 1343 | "binary-extensions": "^2.0.0" 1344 | } 1345 | }, 1346 | "is-buffer": { 1347 | "version": "1.1.6", 1348 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1349 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" 1350 | }, 1351 | "is-callable": { 1352 | "version": "1.1.5", 1353 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.5.tgz", 1354 | "integrity": "sha512-ESKv5sMCJB2jnHTWZ3O5itG+O128Hsus4K4Qh1h2/cgn2vbgnLSVqfV46AeJA9D5EeeLa9w81KUXMtn34zhX+Q==", 1355 | "dev": true 1356 | }, 1357 | "is-date-object": { 1358 | "version": "1.0.2", 1359 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1360 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1361 | "dev": true 1362 | }, 1363 | "is-expression": { 1364 | "version": "3.0.0", 1365 | "resolved": "https://registry.npmjs.org/is-expression/-/is-expression-3.0.0.tgz", 1366 | "integrity": "sha1-Oayqa+f9HzRx3ELHQW5hwkMXrJ8=", 1367 | "requires": { 1368 | "acorn": "~4.0.2", 1369 | "object-assign": "^4.0.1" 1370 | }, 1371 | "dependencies": { 1372 | "acorn": { 1373 | "version": "4.0.13", 1374 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", 1375 | "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" 1376 | } 1377 | } 1378 | }, 1379 | "is-extglob": { 1380 | "version": "2.1.1", 1381 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1382 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1383 | "dev": true 1384 | }, 1385 | "is-fullwidth-code-point": { 1386 | "version": "2.0.0", 1387 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1388 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 1389 | }, 1390 | "is-glob": { 1391 | "version": "4.0.1", 1392 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1393 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1394 | "dev": true, 1395 | "requires": { 1396 | "is-extglob": "^2.1.1" 1397 | } 1398 | }, 1399 | "is-number": { 1400 | "version": "7.0.0", 1401 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1402 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1403 | "dev": true 1404 | }, 1405 | "is-promise": { 1406 | "version": "2.1.0", 1407 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1408 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 1409 | }, 1410 | "is-regex": { 1411 | "version": "1.0.5", 1412 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.5.tgz", 1413 | "integrity": "sha512-vlKW17SNq44owv5AQR3Cq0bQPEb8+kF3UKZ2fiZNOWtztYE5i0CzCZxFDwO58qAOWtxdBRVO/V5Qin1wjCqFYQ==", 1414 | "requires": { 1415 | "has": "^1.0.3" 1416 | } 1417 | }, 1418 | "is-symbol": { 1419 | "version": "1.0.3", 1420 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1421 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1422 | "dev": true, 1423 | "requires": { 1424 | "has-symbols": "^1.0.1" 1425 | } 1426 | }, 1427 | "isarray": { 1428 | "version": "1.0.0", 1429 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1430 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1431 | }, 1432 | "isexe": { 1433 | "version": "2.0.0", 1434 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1435 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1436 | "dev": true 1437 | }, 1438 | "js-stringify": { 1439 | "version": "1.0.2", 1440 | "resolved": "https://registry.npmjs.org/js-stringify/-/js-stringify-1.0.2.tgz", 1441 | "integrity": "sha1-Fzb939lyTyijaCrcYjCufk6Weds=" 1442 | }, 1443 | "js-yaml": { 1444 | "version": "3.13.1", 1445 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1446 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1447 | "dev": true, 1448 | "requires": { 1449 | "argparse": "^1.0.7", 1450 | "esprima": "^4.0.0" 1451 | } 1452 | }, 1453 | "jsonwebtoken": { 1454 | "version": "8.5.1", 1455 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 1456 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 1457 | "requires": { 1458 | "jws": "^3.2.2", 1459 | "lodash.includes": "^4.3.0", 1460 | "lodash.isboolean": "^3.0.3", 1461 | "lodash.isinteger": "^4.0.4", 1462 | "lodash.isnumber": "^3.0.3", 1463 | "lodash.isplainobject": "^4.0.6", 1464 | "lodash.isstring": "^4.0.1", 1465 | "lodash.once": "^4.0.0", 1466 | "ms": "^2.1.1", 1467 | "semver": "^5.6.0" 1468 | }, 1469 | "dependencies": { 1470 | "ms": { 1471 | "version": "2.1.2", 1472 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1473 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1474 | } 1475 | } 1476 | }, 1477 | "jwa": { 1478 | "version": "1.4.1", 1479 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 1480 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 1481 | "requires": { 1482 | "buffer-equal-constant-time": "1.0.1", 1483 | "ecdsa-sig-formatter": "1.0.11", 1484 | "safe-buffer": "^5.0.1" 1485 | } 1486 | }, 1487 | "jws": { 1488 | "version": "3.2.2", 1489 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 1490 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 1491 | "requires": { 1492 | "jwa": "^1.4.1", 1493 | "safe-buffer": "^5.0.1" 1494 | } 1495 | }, 1496 | "kareem": { 1497 | "version": "2.3.1", 1498 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.1.tgz", 1499 | "integrity": "sha512-l3hLhffs9zqoDe8zjmb/mAN4B8VT3L56EUvKNqLFVs9YlFA+zx7ke1DO8STAdDyYNkeSo1nKmjuvQeI12So8Xw==" 1500 | }, 1501 | "kerberos": { 1502 | "version": "1.1.3", 1503 | "resolved": "https://registry.npmjs.org/kerberos/-/kerberos-1.1.3.tgz", 1504 | "integrity": "sha512-R6LdXnkSTALLnrKaByYdIc+eRNhDf+ezA83BeqHiCcKhKE9R6m1PBD579YuX9KANPAakhWHEu/u6H7ZQBc/+Wg==", 1505 | "requires": { 1506 | "bindings": "^1.5.0", 1507 | "nan": "^2.14.0", 1508 | "prebuild-install": "^5.3.0" 1509 | } 1510 | }, 1511 | "kind-of": { 1512 | "version": "3.2.2", 1513 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1514 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1515 | "requires": { 1516 | "is-buffer": "^1.1.5" 1517 | } 1518 | }, 1519 | "lazy-cache": { 1520 | "version": "1.0.4", 1521 | "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", 1522 | "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=" 1523 | }, 1524 | "locate-path": { 1525 | "version": "3.0.0", 1526 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1527 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1528 | "dev": true, 1529 | "requires": { 1530 | "p-locate": "^3.0.0", 1531 | "path-exists": "^3.0.0" 1532 | } 1533 | }, 1534 | "lockfile": { 1535 | "version": "1.0.4", 1536 | "resolved": "https://registry.npmjs.org/lockfile/-/lockfile-1.0.4.tgz", 1537 | "integrity": "sha512-cvbTwETRfsFh4nHsL1eGWapU1XFi5Ot9E85sWAwia7Y7EgB7vfqcZhTKZ+l7hCGxSPoushMv5GKhT5PdLv03WA==", 1538 | "dev": true, 1539 | "requires": { 1540 | "signal-exit": "^3.0.2" 1541 | } 1542 | }, 1543 | "lodash": { 1544 | "version": "4.17.15", 1545 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 1546 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" 1547 | }, 1548 | "lodash.includes": { 1549 | "version": "4.3.0", 1550 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1551 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1552 | }, 1553 | "lodash.isboolean": { 1554 | "version": "3.0.3", 1555 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1556 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1557 | }, 1558 | "lodash.isinteger": { 1559 | "version": "4.0.4", 1560 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1561 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1562 | }, 1563 | "lodash.isnumber": { 1564 | "version": "3.0.3", 1565 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1566 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1567 | }, 1568 | "lodash.isplainobject": { 1569 | "version": "4.0.6", 1570 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1571 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1572 | }, 1573 | "lodash.isstring": { 1574 | "version": "4.0.1", 1575 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1576 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1577 | }, 1578 | "lodash.once": { 1579 | "version": "4.1.1", 1580 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1581 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1582 | }, 1583 | "log-symbols": { 1584 | "version": "3.0.0", 1585 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 1586 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 1587 | "dev": true, 1588 | "requires": { 1589 | "chalk": "^2.4.2" 1590 | } 1591 | }, 1592 | "longest": { 1593 | "version": "1.0.1", 1594 | "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", 1595 | "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=" 1596 | }, 1597 | "make-dir": { 1598 | "version": "3.1.0", 1599 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1600 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1601 | "dev": true, 1602 | "requires": { 1603 | "semver": "^6.0.0" 1604 | }, 1605 | "dependencies": { 1606 | "semver": { 1607 | "version": "6.3.0", 1608 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1609 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1610 | "dev": true 1611 | } 1612 | } 1613 | }, 1614 | "md5-file": { 1615 | "version": "4.0.0", 1616 | "resolved": "https://registry.npmjs.org/md5-file/-/md5-file-4.0.0.tgz", 1617 | "integrity": "sha512-UC0qFwyAjn4YdPpKaDNw6gNxRf7Mcx7jC1UGCY4boCzgvU2Aoc1mOGzTtrjjLKhM5ivsnhoKpQVxKPp+1j1qwg==", 1618 | "dev": true 1619 | }, 1620 | "media-typer": { 1621 | "version": "0.3.0", 1622 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1623 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1624 | }, 1625 | "memory-pager": { 1626 | "version": "1.5.0", 1627 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1628 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1629 | "optional": true 1630 | }, 1631 | "merge-descriptors": { 1632 | "version": "1.0.1", 1633 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1634 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1635 | }, 1636 | "methods": { 1637 | "version": "1.1.2", 1638 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1639 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1640 | }, 1641 | "mime": { 1642 | "version": "1.6.0", 1643 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1644 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1645 | "dev": true 1646 | }, 1647 | "mime-db": { 1648 | "version": "1.43.0", 1649 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.43.0.tgz", 1650 | "integrity": "sha512-+5dsGEEovYbT8UY9yD7eE4XTc4UwJ1jBYlgaQQF38ENsKR3wj/8q8RFZrF9WIZpB2V1ArTVFUva8sAul1NzRzQ==" 1651 | }, 1652 | "mime-types": { 1653 | "version": "2.1.26", 1654 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.26.tgz", 1655 | "integrity": "sha512-01paPWYgLrkqAyrlDorC1uDwl2p3qZT7yl806vW7DvDoxwXi46jsjFbg+WdwotBIk6/MbEhO/dh5aZ5sNj/dWQ==", 1656 | "requires": { 1657 | "mime-db": "1.43.0" 1658 | } 1659 | }, 1660 | "mimic-response": { 1661 | "version": "2.1.0", 1662 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz", 1663 | "integrity": "sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA==" 1664 | }, 1665 | "minimatch": { 1666 | "version": "3.0.4", 1667 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1668 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1669 | "dev": true, 1670 | "requires": { 1671 | "brace-expansion": "^1.1.7" 1672 | } 1673 | }, 1674 | "minimist": { 1675 | "version": "1.2.5", 1676 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1677 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1678 | }, 1679 | "mkdirp": { 1680 | "version": "0.5.3", 1681 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.3.tgz", 1682 | "integrity": "sha512-P+2gwrFqx8lhew375MQHHeTlY8AuOJSrGf0R5ddkEndUkmwpgUob/vQuBD1V22/Cw1/lJr4x+EjllSezBThzBg==", 1683 | "requires": { 1684 | "minimist": "^1.2.5" 1685 | } 1686 | }, 1687 | "mocha": { 1688 | "version": "7.1.1", 1689 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-7.1.1.tgz", 1690 | "integrity": "sha512-3qQsu3ijNS3GkWcccT5Zw0hf/rWvu1fTN9sPvEd81hlwsr30GX2GcDSSoBxo24IR8FelmrAydGC6/1J5QQP4WA==", 1691 | "dev": true, 1692 | "requires": { 1693 | "ansi-colors": "3.2.3", 1694 | "browser-stdout": "1.3.1", 1695 | "chokidar": "3.3.0", 1696 | "debug": "3.2.6", 1697 | "diff": "3.5.0", 1698 | "escape-string-regexp": "1.0.5", 1699 | "find-up": "3.0.0", 1700 | "glob": "7.1.3", 1701 | "growl": "1.10.5", 1702 | "he": "1.2.0", 1703 | "js-yaml": "3.13.1", 1704 | "log-symbols": "3.0.0", 1705 | "minimatch": "3.0.4", 1706 | "mkdirp": "0.5.3", 1707 | "ms": "2.1.1", 1708 | "node-environment-flags": "1.0.6", 1709 | "object.assign": "4.1.0", 1710 | "strip-json-comments": "2.0.1", 1711 | "supports-color": "6.0.0", 1712 | "which": "1.3.1", 1713 | "wide-align": "1.1.3", 1714 | "yargs": "13.3.2", 1715 | "yargs-parser": "13.1.2", 1716 | "yargs-unparser": "1.6.0" 1717 | }, 1718 | "dependencies": { 1719 | "ansi-regex": { 1720 | "version": "4.1.0", 1721 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1722 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1723 | "dev": true 1724 | }, 1725 | "cliui": { 1726 | "version": "5.0.0", 1727 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 1728 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 1729 | "dev": true, 1730 | "requires": { 1731 | "string-width": "^3.1.0", 1732 | "strip-ansi": "^5.2.0", 1733 | "wrap-ansi": "^5.1.0" 1734 | } 1735 | }, 1736 | "debug": { 1737 | "version": "3.2.6", 1738 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1739 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1740 | "dev": true, 1741 | "requires": { 1742 | "ms": "^2.1.1" 1743 | } 1744 | }, 1745 | "ms": { 1746 | "version": "2.1.1", 1747 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1748 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1749 | "dev": true 1750 | }, 1751 | "string-width": { 1752 | "version": "3.1.0", 1753 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1754 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1755 | "dev": true, 1756 | "requires": { 1757 | "emoji-regex": "^7.0.1", 1758 | "is-fullwidth-code-point": "^2.0.0", 1759 | "strip-ansi": "^5.1.0" 1760 | } 1761 | }, 1762 | "strip-ansi": { 1763 | "version": "5.2.0", 1764 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1765 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1766 | "dev": true, 1767 | "requires": { 1768 | "ansi-regex": "^4.1.0" 1769 | } 1770 | }, 1771 | "yargs": { 1772 | "version": "13.3.2", 1773 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 1774 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 1775 | "dev": true, 1776 | "requires": { 1777 | "cliui": "^5.0.0", 1778 | "find-up": "^3.0.0", 1779 | "get-caller-file": "^2.0.1", 1780 | "require-directory": "^2.1.1", 1781 | "require-main-filename": "^2.0.0", 1782 | "set-blocking": "^2.0.0", 1783 | "string-width": "^3.0.0", 1784 | "which-module": "^2.0.0", 1785 | "y18n": "^4.0.0", 1786 | "yargs-parser": "^13.1.2" 1787 | } 1788 | } 1789 | } 1790 | }, 1791 | "mongodb": { 1792 | "version": "3.5.5", 1793 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.5.5.tgz", 1794 | "integrity": "sha512-GCjDxR3UOltDq00Zcpzql6dQo1sVry60OXJY3TDmFc2SWFY6c8Gn1Ardidc5jDirvJrx2GC3knGOImKphbSL3A==", 1795 | "requires": { 1796 | "bl": "^2.2.0", 1797 | "bson": "^1.1.1", 1798 | "denque": "^1.4.1", 1799 | "require_optional": "^1.0.1", 1800 | "safe-buffer": "^5.1.2", 1801 | "saslprep": "^1.0.0" 1802 | } 1803 | }, 1804 | "mongodb-memory-server": { 1805 | "version": "6.6.1", 1806 | "resolved": "https://registry.npmjs.org/mongodb-memory-server/-/mongodb-memory-server-6.6.1.tgz", 1807 | "integrity": "sha512-qnGpGE50snhS3IgKwiPlxnL5wFWPxWutqcCqlsbb68FKohaEIsvi/gMBqJbBLF2l2sQu4a4aJofuKFudSI38vQ==", 1808 | "dev": true, 1809 | "requires": { 1810 | "mongodb-memory-server-core": "6.6.1" 1811 | } 1812 | }, 1813 | "mongodb-memory-server-core": { 1814 | "version": "6.6.1", 1815 | "resolved": "https://registry.npmjs.org/mongodb-memory-server-core/-/mongodb-memory-server-core-6.6.1.tgz", 1816 | "integrity": "sha512-k6YowfiHxUdGwR/AhXuyv1V3VW2NkA6VuICQfUqZGeqENsExbnL05oKpavAXrmCGxcabXZ3IMvcgmUwmlJAGng==", 1817 | "dev": true, 1818 | "requires": { 1819 | "@types/cross-spawn": "^6.0.1", 1820 | "@types/debug": "^4.1.5", 1821 | "@types/dedent": "^0.7.0", 1822 | "@types/find-cache-dir": "^3.2.0", 1823 | "@types/find-package-json": "^1.1.1", 1824 | "@types/get-port": "^4.0.1", 1825 | "@types/lockfile": "^1.0.1", 1826 | "@types/md5-file": "^4.0.1", 1827 | "@types/mkdirp": "^1.0.0", 1828 | "@types/tmp": "0.1.0", 1829 | "@types/uuid": "7.0.0", 1830 | "camelcase": "^5.3.1", 1831 | "cross-spawn": "^7.0.1", 1832 | "debug": "^4.1.1", 1833 | "dedent": "^0.7.0", 1834 | "find-cache-dir": "3.3.1", 1835 | "find-package-json": "^1.2.0", 1836 | "get-port": "5.1.1", 1837 | "https-proxy-agent": "5.0.0", 1838 | "lockfile": "^1.0.4", 1839 | "md5-file": "^4.0.0", 1840 | "mkdirp": "^1.0.3", 1841 | "mongodb": "^3.5.4", 1842 | "tar-stream": "^2.1.1", 1843 | "tmp": "^0.1.0", 1844 | "uuid": "^7.0.2", 1845 | "yauzl": "^2.10.0" 1846 | }, 1847 | "dependencies": { 1848 | "camelcase": { 1849 | "version": "5.3.1", 1850 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 1851 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 1852 | "dev": true 1853 | }, 1854 | "mkdirp": { 1855 | "version": "1.0.4", 1856 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1857 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1858 | "dev": true 1859 | } 1860 | } 1861 | }, 1862 | "mongoose": { 1863 | "version": "5.9.5", 1864 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.9.5.tgz", 1865 | "integrity": "sha512-2kMNZCZRWCMtww4f//CwdGH6BjO3+9/c3YdsC6nbzdJVyl8+GRtNfgrKUge3226VZXXLJa6LwxXN2K8/Dh4irg==", 1866 | "requires": { 1867 | "bson": "~1.1.1", 1868 | "kareem": "2.3.1", 1869 | "mongodb": "3.5.5", 1870 | "mongoose-legacy-pluralize": "1.0.2", 1871 | "mpath": "0.6.0", 1872 | "mquery": "3.2.2", 1873 | "ms": "2.1.2", 1874 | "regexp-clone": "1.0.0", 1875 | "safe-buffer": "5.1.2", 1876 | "sift": "7.0.1", 1877 | "sliced": "1.0.1" 1878 | }, 1879 | "dependencies": { 1880 | "ms": { 1881 | "version": "2.1.2", 1882 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1883 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1884 | }, 1885 | "safe-buffer": { 1886 | "version": "5.1.2", 1887 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1888 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1889 | } 1890 | } 1891 | }, 1892 | "mongoose-deep-populate": { 1893 | "version": "3.1.1", 1894 | "resolved": "https://registry.npmjs.org/mongoose-deep-populate/-/mongoose-deep-populate-3.1.1.tgz", 1895 | "integrity": "sha1-Vh9+iFZs3waXVZyf4ZDVgckDhEI=" 1896 | }, 1897 | "mongoose-legacy-pluralize": { 1898 | "version": "1.0.2", 1899 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 1900 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 1901 | }, 1902 | "morgan": { 1903 | "version": "1.9.1", 1904 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.9.1.tgz", 1905 | "integrity": "sha512-HQStPIV4y3afTiCYVxirakhlCfGkI161c76kKFca7Fk1JusM//Qeo1ej2XaMniiNeaZklMVrh3vTtIzpzwbpmA==", 1906 | "requires": { 1907 | "basic-auth": "~2.0.0", 1908 | "debug": "2.6.9", 1909 | "depd": "~1.1.2", 1910 | "on-finished": "~2.3.0", 1911 | "on-headers": "~1.0.1" 1912 | }, 1913 | "dependencies": { 1914 | "debug": { 1915 | "version": "2.6.9", 1916 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1917 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1918 | "requires": { 1919 | "ms": "2.0.0" 1920 | } 1921 | }, 1922 | "ms": { 1923 | "version": "2.0.0", 1924 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1925 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1926 | } 1927 | } 1928 | }, 1929 | "mpath": { 1930 | "version": "0.6.0", 1931 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.6.0.tgz", 1932 | "integrity": "sha512-i75qh79MJ5Xo/sbhxrDrPSEG0H/mr1kcZXJ8dH6URU5jD/knFxCVqVC/gVSW7GIXL/9hHWlT9haLbCXWOll3qw==" 1933 | }, 1934 | "mquery": { 1935 | "version": "3.2.2", 1936 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.2.tgz", 1937 | "integrity": "sha512-XB52992COp0KP230I3qloVUbkLUxJIu328HBP2t2EsxSFtf4W1HPSOBWOXf1bqxK4Xbb66lfMJ+Bpfd9/yZE1Q==", 1938 | "requires": { 1939 | "bluebird": "3.5.1", 1940 | "debug": "3.1.0", 1941 | "regexp-clone": "^1.0.0", 1942 | "safe-buffer": "5.1.2", 1943 | "sliced": "1.0.1" 1944 | }, 1945 | "dependencies": { 1946 | "debug": { 1947 | "version": "3.1.0", 1948 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1949 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1950 | "requires": { 1951 | "ms": "2.0.0" 1952 | } 1953 | }, 1954 | "ms": { 1955 | "version": "2.0.0", 1956 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1957 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1958 | }, 1959 | "safe-buffer": { 1960 | "version": "5.1.2", 1961 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1962 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1963 | } 1964 | } 1965 | }, 1966 | "ms": { 1967 | "version": "2.1.2", 1968 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1969 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1970 | }, 1971 | "nan": { 1972 | "version": "2.14.0", 1973 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz", 1974 | "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==" 1975 | }, 1976 | "napi-build-utils": { 1977 | "version": "1.0.2", 1978 | "resolved": "https://registry.npmjs.org/napi-build-utils/-/napi-build-utils-1.0.2.tgz", 1979 | "integrity": "sha512-ONmRUqK7zj7DWX0D9ADe03wbwOBZxNAfF20PlGfCWQcD3+/MakShIHrMqx9YwPTfxDdF1zLeL+RGZiR9kGMLdg==" 1980 | }, 1981 | "negotiator": { 1982 | "version": "0.6.2", 1983 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1984 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 1985 | }, 1986 | "node-abi": { 1987 | "version": "2.15.0", 1988 | "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-2.15.0.tgz", 1989 | "integrity": "sha512-FeLpTS0F39U7hHZU1srAK4Vx+5AHNVOTP+hxBNQknR/54laTHSFIJkDWDqiquY1LeLUgTfPN7sLPhMubx0PLAg==", 1990 | "requires": { 1991 | "semver": "^5.4.1" 1992 | } 1993 | }, 1994 | "node-environment-flags": { 1995 | "version": "1.0.6", 1996 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.6.tgz", 1997 | "integrity": "sha512-5Evy2epuL+6TM0lCQGpFIj6KwiEsGh1SrHUhTbNX+sLbBtjidPZFAnVK9y5yU1+h//RitLbRHTIMyxQPtxMdHw==", 1998 | "dev": true, 1999 | "requires": { 2000 | "object.getownpropertydescriptors": "^2.0.3", 2001 | "semver": "^5.7.0" 2002 | } 2003 | }, 2004 | "noop-logger": { 2005 | "version": "0.1.1", 2006 | "resolved": "https://registry.npmjs.org/noop-logger/-/noop-logger-0.1.1.tgz", 2007 | "integrity": "sha1-lKKxYzxPExdVMAfYlm/Q6EG2pMI=" 2008 | }, 2009 | "normalize-path": { 2010 | "version": "3.0.0", 2011 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2012 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2013 | "dev": true 2014 | }, 2015 | "npmlog": { 2016 | "version": "4.1.2", 2017 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 2018 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 2019 | "requires": { 2020 | "are-we-there-yet": "~1.1.2", 2021 | "console-control-strings": "~1.1.0", 2022 | "gauge": "~2.7.3", 2023 | "set-blocking": "~2.0.0" 2024 | } 2025 | }, 2026 | "number-is-nan": { 2027 | "version": "1.0.1", 2028 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 2029 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 2030 | }, 2031 | "object-assign": { 2032 | "version": "4.1.1", 2033 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2034 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 2035 | }, 2036 | "object-inspect": { 2037 | "version": "1.7.0", 2038 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.7.0.tgz", 2039 | "integrity": "sha512-a7pEHdh1xKIAgTySUGgLMx/xwDZskN1Ud6egYYN3EdRW4ZMPNEDUTF+hwy2LUC+Bl+SyLXANnwz/jyh/qutKUw==", 2040 | "dev": true 2041 | }, 2042 | "object-keys": { 2043 | "version": "1.1.1", 2044 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2045 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2046 | "dev": true 2047 | }, 2048 | "object.assign": { 2049 | "version": "4.1.0", 2050 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 2051 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 2052 | "dev": true, 2053 | "requires": { 2054 | "define-properties": "^1.1.2", 2055 | "function-bind": "^1.1.1", 2056 | "has-symbols": "^1.0.0", 2057 | "object-keys": "^1.0.11" 2058 | } 2059 | }, 2060 | "object.getownpropertydescriptors": { 2061 | "version": "2.1.0", 2062 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", 2063 | "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", 2064 | "dev": true, 2065 | "requires": { 2066 | "define-properties": "^1.1.3", 2067 | "es-abstract": "^1.17.0-next.1" 2068 | } 2069 | }, 2070 | "on-finished": { 2071 | "version": "2.3.0", 2072 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2073 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2074 | "requires": { 2075 | "ee-first": "1.1.1" 2076 | } 2077 | }, 2078 | "on-headers": { 2079 | "version": "1.0.2", 2080 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 2081 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" 2082 | }, 2083 | "once": { 2084 | "version": "1.4.0", 2085 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2086 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2087 | "requires": { 2088 | "wrappy": "1" 2089 | } 2090 | }, 2091 | "p-limit": { 2092 | "version": "2.2.2", 2093 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.2.tgz", 2094 | "integrity": "sha512-WGR+xHecKTr7EbUEhyLSh5Dube9JtdiG78ufaeLxTgpudf/20KqyMioIUZJAezlTIi6evxuoUs9YXc11cU+yzQ==", 2095 | "dev": true, 2096 | "requires": { 2097 | "p-try": "^2.0.0" 2098 | } 2099 | }, 2100 | "p-locate": { 2101 | "version": "3.0.0", 2102 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2103 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2104 | "dev": true, 2105 | "requires": { 2106 | "p-limit": "^2.0.0" 2107 | } 2108 | }, 2109 | "p-try": { 2110 | "version": "2.2.0", 2111 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 2112 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 2113 | "dev": true 2114 | }, 2115 | "parseurl": { 2116 | "version": "1.3.3", 2117 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2118 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2119 | }, 2120 | "passport": { 2121 | "version": "0.3.2", 2122 | "resolved": "https://registry.npmjs.org/passport/-/passport-0.3.2.tgz", 2123 | "integrity": "sha1-ndAJ+RXo/glbASSgG4+C2gdRAQI=", 2124 | "requires": { 2125 | "passport-strategy": "1.x.x", 2126 | "pause": "0.0.1" 2127 | } 2128 | }, 2129 | "passport-local": { 2130 | "version": "1.0.0", 2131 | "resolved": "https://registry.npmjs.org/passport-local/-/passport-local-1.0.0.tgz", 2132 | "integrity": "sha1-H+YyaMkudWBmJkN+O5BmYsFbpu4=", 2133 | "requires": { 2134 | "passport-strategy": "1.x.x" 2135 | } 2136 | }, 2137 | "passport-local-mongoose": { 2138 | "version": "3.1.0", 2139 | "resolved": "https://registry.npmjs.org/passport-local-mongoose/-/passport-local-mongoose-3.1.0.tgz", 2140 | "integrity": "sha1-najQt5KHDDhFAu6x99MONL/xQsY=", 2141 | "requires": { 2142 | "generaterr": "^1.2.0", 2143 | "passport-local": "^1.0.0", 2144 | "scmp": "^1.0.0" 2145 | } 2146 | }, 2147 | "passport-strategy": { 2148 | "version": "1.0.0", 2149 | "resolved": "https://registry.npmjs.org/passport-strategy/-/passport-strategy-1.0.0.tgz", 2150 | "integrity": "sha1-tVOaqPwiWj0a0XlHbd8ja0QPUuQ=" 2151 | }, 2152 | "passport-stub": { 2153 | "version": "1.1.1", 2154 | "resolved": "https://registry.npmjs.org/passport-stub/-/passport-stub-1.1.1.tgz", 2155 | "integrity": "sha1-fIJ2lDL+o0T0Y3liG+bG9nYPtjw=" 2156 | }, 2157 | "path-exists": { 2158 | "version": "3.0.0", 2159 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2160 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2161 | "dev": true 2162 | }, 2163 | "path-is-absolute": { 2164 | "version": "1.0.1", 2165 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2166 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2167 | "dev": true 2168 | }, 2169 | "path-key": { 2170 | "version": "3.1.1", 2171 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2172 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2173 | "dev": true 2174 | }, 2175 | "path-parse": { 2176 | "version": "1.0.6", 2177 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2178 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" 2179 | }, 2180 | "path-to-regexp": { 2181 | "version": "0.1.7", 2182 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2183 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2184 | }, 2185 | "pause": { 2186 | "version": "0.0.1", 2187 | "resolved": "https://registry.npmjs.org/pause/-/pause-0.0.1.tgz", 2188 | "integrity": "sha1-HUCLP9t2kjuVQ9lvtMnf1TXZy10=" 2189 | }, 2190 | "pend": { 2191 | "version": "1.2.0", 2192 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 2193 | "integrity": "sha1-elfrVQpng/kRUzH89GY9XI4AelA=", 2194 | "dev": true 2195 | }, 2196 | "picomatch": { 2197 | "version": "2.2.1", 2198 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.1.tgz", 2199 | "integrity": "sha512-ISBaA8xQNmwELC7eOjqFKMESB2VIqt4PPDD0nsS95b/9dZXvVKOlz9keMSnoGGKcOHXfTvDD6WMaRoSc9UuhRA==", 2200 | "dev": true 2201 | }, 2202 | "pkg-dir": { 2203 | "version": "4.2.0", 2204 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 2205 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 2206 | "dev": true, 2207 | "requires": { 2208 | "find-up": "^4.0.0" 2209 | }, 2210 | "dependencies": { 2211 | "find-up": { 2212 | "version": "4.1.0", 2213 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2214 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2215 | "dev": true, 2216 | "requires": { 2217 | "locate-path": "^5.0.0", 2218 | "path-exists": "^4.0.0" 2219 | } 2220 | }, 2221 | "locate-path": { 2222 | "version": "5.0.0", 2223 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2224 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2225 | "dev": true, 2226 | "requires": { 2227 | "p-locate": "^4.1.0" 2228 | } 2229 | }, 2230 | "p-locate": { 2231 | "version": "4.1.0", 2232 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2233 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2234 | "dev": true, 2235 | "requires": { 2236 | "p-limit": "^2.2.0" 2237 | } 2238 | }, 2239 | "path-exists": { 2240 | "version": "4.0.0", 2241 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2242 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2243 | "dev": true 2244 | } 2245 | } 2246 | }, 2247 | "pop-iterate": { 2248 | "version": "1.0.1", 2249 | "resolved": "https://registry.npmjs.org/pop-iterate/-/pop-iterate-1.0.1.tgz", 2250 | "integrity": "sha1-zqz9q0q/NT16DyqqLB/Hs/lBO6M=" 2251 | }, 2252 | "prebuild-install": { 2253 | "version": "5.3.3", 2254 | "resolved": "https://registry.npmjs.org/prebuild-install/-/prebuild-install-5.3.3.tgz", 2255 | "integrity": "sha512-GV+nsUXuPW2p8Zy7SarF/2W/oiK8bFQgJcncoJ0d7kRpekEA0ftChjfEaF9/Y+QJEc/wFR7RAEa8lYByuUIe2g==", 2256 | "requires": { 2257 | "detect-libc": "^1.0.3", 2258 | "expand-template": "^2.0.3", 2259 | "github-from-package": "0.0.0", 2260 | "minimist": "^1.2.0", 2261 | "mkdirp": "^0.5.1", 2262 | "napi-build-utils": "^1.0.1", 2263 | "node-abi": "^2.7.0", 2264 | "noop-logger": "^0.1.1", 2265 | "npmlog": "^4.0.1", 2266 | "pump": "^3.0.0", 2267 | "rc": "^1.2.7", 2268 | "simple-get": "^3.0.3", 2269 | "tar-fs": "^2.0.0", 2270 | "tunnel-agent": "^0.6.0", 2271 | "which-pm-runs": "^1.0.0" 2272 | } 2273 | }, 2274 | "process-nextick-args": { 2275 | "version": "2.0.1", 2276 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2277 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 2278 | }, 2279 | "proxy-addr": { 2280 | "version": "2.0.6", 2281 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", 2282 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", 2283 | "requires": { 2284 | "forwarded": "~0.1.2", 2285 | "ipaddr.js": "1.9.1" 2286 | } 2287 | }, 2288 | "pug": { 2289 | "version": "2.0.4", 2290 | "resolved": "https://registry.npmjs.org/pug/-/pug-2.0.4.tgz", 2291 | "integrity": "sha512-XhoaDlvi6NIzL49nu094R2NA6P37ijtgMDuWE+ofekDChvfKnzFal60bhSdiy8y2PBO6fmz3oMEIcfpBVRUdvw==", 2292 | "requires": { 2293 | "pug-code-gen": "^2.0.2", 2294 | "pug-filters": "^3.1.1", 2295 | "pug-lexer": "^4.1.0", 2296 | "pug-linker": "^3.0.6", 2297 | "pug-load": "^2.0.12", 2298 | "pug-parser": "^5.0.1", 2299 | "pug-runtime": "^2.0.5", 2300 | "pug-strip-comments": "^1.0.4" 2301 | } 2302 | }, 2303 | "pug-attrs": { 2304 | "version": "2.0.4", 2305 | "resolved": "https://registry.npmjs.org/pug-attrs/-/pug-attrs-2.0.4.tgz", 2306 | "integrity": "sha512-TaZ4Z2TWUPDJcV3wjU3RtUXMrd3kM4Wzjbe3EWnSsZPsJ3LDI0F3yCnf2/W7PPFF+edUFQ0HgDL1IoxSz5K8EQ==", 2307 | "requires": { 2308 | "constantinople": "^3.0.1", 2309 | "js-stringify": "^1.0.1", 2310 | "pug-runtime": "^2.0.5" 2311 | } 2312 | }, 2313 | "pug-code-gen": { 2314 | "version": "2.0.2", 2315 | "resolved": "https://registry.npmjs.org/pug-code-gen/-/pug-code-gen-2.0.2.tgz", 2316 | "integrity": "sha512-kROFWv/AHx/9CRgoGJeRSm+4mLWchbgpRzTEn8XCiwwOy6Vh0gAClS8Vh5TEJ9DBjaP8wCjS3J6HKsEsYdvaCw==", 2317 | "requires": { 2318 | "constantinople": "^3.1.2", 2319 | "doctypes": "^1.1.0", 2320 | "js-stringify": "^1.0.1", 2321 | "pug-attrs": "^2.0.4", 2322 | "pug-error": "^1.3.3", 2323 | "pug-runtime": "^2.0.5", 2324 | "void-elements": "^2.0.1", 2325 | "with": "^5.0.0" 2326 | }, 2327 | "dependencies": { 2328 | "acorn": { 2329 | "version": "3.3.0", 2330 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", 2331 | "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=" 2332 | }, 2333 | "acorn-globals": { 2334 | "version": "3.1.0", 2335 | "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-3.1.0.tgz", 2336 | "integrity": "sha1-/YJw9x+7SZawBPqIDuXUZXOnMb8=", 2337 | "requires": { 2338 | "acorn": "^4.0.4" 2339 | }, 2340 | "dependencies": { 2341 | "acorn": { 2342 | "version": "4.0.13", 2343 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", 2344 | "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" 2345 | } 2346 | } 2347 | }, 2348 | "constantinople": { 2349 | "version": "3.1.2", 2350 | "resolved": "https://registry.npmjs.org/constantinople/-/constantinople-3.1.2.tgz", 2351 | "integrity": "sha512-yePcBqEFhLOqSBtwYOGGS1exHo/s1xjekXiinh4itpNQGCu4KA1euPh1fg07N2wMITZXQkBz75Ntdt1ctGZouw==", 2352 | "requires": { 2353 | "@types/babel-types": "^7.0.0", 2354 | "@types/babylon": "^6.16.2", 2355 | "babel-types": "^6.26.0", 2356 | "babylon": "^6.18.0" 2357 | } 2358 | }, 2359 | "with": { 2360 | "version": "5.1.1", 2361 | "resolved": "https://registry.npmjs.org/with/-/with-5.1.1.tgz", 2362 | "integrity": "sha1-+k2qktrzLE6pTtRTyB8EaGtXXf4=", 2363 | "requires": { 2364 | "acorn": "^3.1.0", 2365 | "acorn-globals": "^3.0.0" 2366 | } 2367 | } 2368 | } 2369 | }, 2370 | "pug-error": { 2371 | "version": "1.3.3", 2372 | "resolved": "https://registry.npmjs.org/pug-error/-/pug-error-1.3.3.tgz", 2373 | "integrity": "sha512-qE3YhESP2mRAWMFJgKdtT5D7ckThRScXRwkfo+Erqga7dyJdY3ZquspprMCj/9sJ2ijm5hXFWQE/A3l4poMWiQ==" 2374 | }, 2375 | "pug-filters": { 2376 | "version": "3.1.1", 2377 | "resolved": "https://registry.npmjs.org/pug-filters/-/pug-filters-3.1.1.tgz", 2378 | "integrity": "sha512-lFfjNyGEyVWC4BwX0WyvkoWLapI5xHSM3xZJFUhx4JM4XyyRdO8Aucc6pCygnqV2uSgJFaJWW3Ft1wCWSoQkQg==", 2379 | "requires": { 2380 | "clean-css": "^4.1.11", 2381 | "constantinople": "^3.0.1", 2382 | "jstransformer": "1.0.0", 2383 | "pug-error": "^1.3.3", 2384 | "pug-walk": "^1.1.8", 2385 | "resolve": "^1.1.6", 2386 | "uglify-js": "^2.6.1" 2387 | }, 2388 | "dependencies": { 2389 | "asap": { 2390 | "version": "2.0.6", 2391 | "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", 2392 | "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=" 2393 | }, 2394 | "clean-css": { 2395 | "version": "4.2.3", 2396 | "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.2.3.tgz", 2397 | "integrity": "sha512-VcMWDN54ZN/DS+g58HYL5/n4Zrqe8vHJpGA8KdgUXFU4fuP/aHNw8eld9SyEIyabIMJX/0RaY/fplOo5hYLSFA==", 2398 | "requires": { 2399 | "source-map": "~0.6.0" 2400 | } 2401 | }, 2402 | "jstransformer": { 2403 | "version": "1.0.0", 2404 | "resolved": "https://registry.npmjs.org/jstransformer/-/jstransformer-1.0.0.tgz", 2405 | "integrity": "sha1-7Yvwkh4vPx7U1cGkT2hwntJHIsM=", 2406 | "requires": { 2407 | "is-promise": "^2.0.0", 2408 | "promise": "^7.0.1" 2409 | } 2410 | }, 2411 | "promise": { 2412 | "version": "7.3.1", 2413 | "resolved": "https://registry.npmjs.org/promise/-/promise-7.3.1.tgz", 2414 | "integrity": "sha512-nolQXZ/4L+bP/UGlkfaIujX9BKxGwmQ9OT4mOt5yvy8iK1h3wqTEJCijzGANTCCl9nWjY41juyAn2K3Q1hLLTg==", 2415 | "requires": { 2416 | "asap": "~2.0.3" 2417 | } 2418 | }, 2419 | "source-map": { 2420 | "version": "0.6.1", 2421 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2422 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" 2423 | } 2424 | } 2425 | }, 2426 | "pug-lexer": { 2427 | "version": "4.1.0", 2428 | "resolved": "https://registry.npmjs.org/pug-lexer/-/pug-lexer-4.1.0.tgz", 2429 | "integrity": "sha512-i55yzEBtjm0mlplW4LoANq7k3S8gDdfC6+LThGEvsK4FuobcKfDAwt6V4jKPH9RtiE3a2Akfg5UpafZ1OksaPA==", 2430 | "requires": { 2431 | "character-parser": "^2.1.1", 2432 | "is-expression": "^3.0.0", 2433 | "pug-error": "^1.3.3" 2434 | }, 2435 | "dependencies": { 2436 | "character-parser": { 2437 | "version": "2.2.0", 2438 | "resolved": "https://registry.npmjs.org/character-parser/-/character-parser-2.2.0.tgz", 2439 | "integrity": "sha1-x84o821LzZdE5f/CxfzeHHMmH8A=", 2440 | "requires": { 2441 | "is-regex": "^1.0.3" 2442 | } 2443 | } 2444 | } 2445 | }, 2446 | "pug-linker": { 2447 | "version": "3.0.6", 2448 | "resolved": "https://registry.npmjs.org/pug-linker/-/pug-linker-3.0.6.tgz", 2449 | "integrity": "sha512-bagfuHttfQOpANGy1Y6NJ+0mNb7dD2MswFG2ZKj22s8g0wVsojpRlqveEQHmgXXcfROB2RT6oqbPYr9EN2ZWzg==", 2450 | "requires": { 2451 | "pug-error": "^1.3.3", 2452 | "pug-walk": "^1.1.8" 2453 | } 2454 | }, 2455 | "pug-load": { 2456 | "version": "2.0.12", 2457 | "resolved": "https://registry.npmjs.org/pug-load/-/pug-load-2.0.12.tgz", 2458 | "integrity": "sha512-UqpgGpyyXRYgJs/X60sE6SIf8UBsmcHYKNaOccyVLEuT6OPBIMo6xMPhoJnqtB3Q3BbO4Z3Bjz5qDsUWh4rXsg==", 2459 | "requires": { 2460 | "object-assign": "^4.1.0", 2461 | "pug-walk": "^1.1.8" 2462 | } 2463 | }, 2464 | "pug-parser": { 2465 | "version": "5.0.1", 2466 | "resolved": "https://registry.npmjs.org/pug-parser/-/pug-parser-5.0.1.tgz", 2467 | "integrity": "sha512-nGHqK+w07p5/PsPIyzkTQfzlYfuqoiGjaoqHv1LjOv2ZLXmGX1O+4Vcvps+P4LhxZ3drYSljjq4b+Naid126wA==", 2468 | "requires": { 2469 | "pug-error": "^1.3.3", 2470 | "token-stream": "0.0.1" 2471 | } 2472 | }, 2473 | "pug-runtime": { 2474 | "version": "2.0.5", 2475 | "resolved": "https://registry.npmjs.org/pug-runtime/-/pug-runtime-2.0.5.tgz", 2476 | "integrity": "sha512-P+rXKn9un4fQY77wtpcuFyvFaBww7/91f3jHa154qU26qFAnOe6SW1CbIDcxiG5lLK9HazYrMCCuDvNgDQNptw==" 2477 | }, 2478 | "pug-strip-comments": { 2479 | "version": "1.0.4", 2480 | "resolved": "https://registry.npmjs.org/pug-strip-comments/-/pug-strip-comments-1.0.4.tgz", 2481 | "integrity": "sha512-i5j/9CS4yFhSxHp5iKPHwigaig/VV9g+FgReLJWWHEHbvKsbqL0oP/K5ubuLco6Wu3Kan5p7u7qk8A4oLLh6vw==", 2482 | "requires": { 2483 | "pug-error": "^1.3.3" 2484 | } 2485 | }, 2486 | "pug-walk": { 2487 | "version": "1.1.8", 2488 | "resolved": "https://registry.npmjs.org/pug-walk/-/pug-walk-1.1.8.tgz", 2489 | "integrity": "sha512-GMu3M5nUL3fju4/egXwZO0XLi6fW/K3T3VTgFQ14GxNi8btlxgT5qZL//JwZFm/2Fa64J/PNS8AZeys3wiMkVA==" 2490 | }, 2491 | "pump": { 2492 | "version": "3.0.0", 2493 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 2494 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 2495 | "requires": { 2496 | "end-of-stream": "^1.1.0", 2497 | "once": "^1.3.1" 2498 | } 2499 | }, 2500 | "q": { 2501 | "version": "2.0.3", 2502 | "resolved": "https://registry.npmjs.org/q/-/q-2.0.3.tgz", 2503 | "integrity": "sha1-dbjbAlWhpa+C9Yw/Oqoe/sfQ0TQ=", 2504 | "requires": { 2505 | "asap": "^2.0.0", 2506 | "pop-iterate": "^1.0.1", 2507 | "weak-map": "^1.0.5" 2508 | }, 2509 | "dependencies": { 2510 | "asap": { 2511 | "version": "2.0.6", 2512 | "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", 2513 | "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=" 2514 | } 2515 | } 2516 | }, 2517 | "qs": { 2518 | "version": "6.7.0", 2519 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 2520 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 2521 | }, 2522 | "querystringify": { 2523 | "version": "2.1.1", 2524 | "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.1.1.tgz", 2525 | "integrity": "sha512-w7fLxIRCRT7U8Qu53jQnJyPkYZIaR4n5151KMfcJlO/A9397Wxb1amJvROTK6TOnp7PfoAmg/qXiNHI+08jRfA==" 2526 | }, 2527 | "random-bytes": { 2528 | "version": "1.0.0", 2529 | "resolved": "https://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz", 2530 | "integrity": "sha1-T2ih3Arli9P7lYSMMDJNt11kNgs=" 2531 | }, 2532 | "range-parser": { 2533 | "version": "1.2.1", 2534 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2535 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 2536 | }, 2537 | "raw-body": { 2538 | "version": "2.4.0", 2539 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 2540 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 2541 | "requires": { 2542 | "bytes": "3.1.0", 2543 | "http-errors": "1.7.2", 2544 | "iconv-lite": "0.4.24", 2545 | "unpipe": "1.0.0" 2546 | } 2547 | }, 2548 | "rc": { 2549 | "version": "1.2.8", 2550 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 2551 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 2552 | "requires": { 2553 | "deep-extend": "^0.6.0", 2554 | "ini": "~1.3.0", 2555 | "minimist": "^1.2.0", 2556 | "strip-json-comments": "~2.0.1" 2557 | } 2558 | }, 2559 | "readable-stream": { 2560 | "version": "2.3.7", 2561 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 2562 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 2563 | "requires": { 2564 | "core-util-is": "~1.0.0", 2565 | "inherits": "~2.0.3", 2566 | "isarray": "~1.0.0", 2567 | "process-nextick-args": "~2.0.0", 2568 | "safe-buffer": "~5.1.1", 2569 | "string_decoder": "~1.1.1", 2570 | "util-deprecate": "~1.0.1" 2571 | }, 2572 | "dependencies": { 2573 | "safe-buffer": { 2574 | "version": "5.1.2", 2575 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2576 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2577 | } 2578 | } 2579 | }, 2580 | "readdirp": { 2581 | "version": "3.2.0", 2582 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.2.0.tgz", 2583 | "integrity": "sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ==", 2584 | "dev": true, 2585 | "requires": { 2586 | "picomatch": "^2.0.4" 2587 | } 2588 | }, 2589 | "regenerator-runtime": { 2590 | "version": "0.11.1", 2591 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", 2592 | "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==" 2593 | }, 2594 | "regexp-clone": { 2595 | "version": "1.0.0", 2596 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 2597 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 2598 | }, 2599 | "repeat-string": { 2600 | "version": "1.6.1", 2601 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2602 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" 2603 | }, 2604 | "require-directory": { 2605 | "version": "2.1.1", 2606 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2607 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2608 | "dev": true 2609 | }, 2610 | "require-main-filename": { 2611 | "version": "2.0.0", 2612 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 2613 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 2614 | "dev": true 2615 | }, 2616 | "require_optional": { 2617 | "version": "1.0.1", 2618 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 2619 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 2620 | "requires": { 2621 | "resolve-from": "^2.0.0", 2622 | "semver": "^5.1.0" 2623 | } 2624 | }, 2625 | "requires-port": { 2626 | "version": "1.0.0", 2627 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 2628 | "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=" 2629 | }, 2630 | "resolve": { 2631 | "version": "1.15.1", 2632 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.15.1.tgz", 2633 | "integrity": "sha512-84oo6ZTtoTUpjgNEr5SJyzQhzL72gaRodsSfyxC/AXRvwu0Yse9H8eF9IpGo7b8YetZhlI6v7ZQ6bKBFV/6S7w==", 2634 | "requires": { 2635 | "path-parse": "^1.0.6" 2636 | } 2637 | }, 2638 | "resolve-from": { 2639 | "version": "2.0.0", 2640 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 2641 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 2642 | }, 2643 | "right-align": { 2644 | "version": "0.1.3", 2645 | "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", 2646 | "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", 2647 | "requires": { 2648 | "align-text": "^0.1.1" 2649 | } 2650 | }, 2651 | "rimraf": { 2652 | "version": "2.7.1", 2653 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 2654 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 2655 | "dev": true, 2656 | "requires": { 2657 | "glob": "^7.1.3" 2658 | } 2659 | }, 2660 | "rootpath": { 2661 | "version": "0.1.2", 2662 | "resolved": "https://registry.npmjs.org/rootpath/-/rootpath-0.1.2.tgz", 2663 | "integrity": "sha1-Wzeah9ypBum5HWkKWZQ5vvJn6ms=" 2664 | }, 2665 | "safe-buffer": { 2666 | "version": "5.2.0", 2667 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", 2668 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==" 2669 | }, 2670 | "safer-buffer": { 2671 | "version": "2.1.2", 2672 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2673 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2674 | }, 2675 | "saslprep": { 2676 | "version": "1.0.3", 2677 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 2678 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 2679 | "optional": true, 2680 | "requires": { 2681 | "sparse-bitfield": "^3.0.3" 2682 | } 2683 | }, 2684 | "scmp": { 2685 | "version": "1.0.2", 2686 | "resolved": "https://registry.npmjs.org/scmp/-/scmp-1.0.2.tgz", 2687 | "integrity": "sha1-vE5OJxMlKwQhDN/5zvOt4sj6c3A=" 2688 | }, 2689 | "semver": { 2690 | "version": "5.7.1", 2691 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2692 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 2693 | }, 2694 | "send": { 2695 | "version": "0.17.1", 2696 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 2697 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 2698 | "requires": { 2699 | "debug": "2.6.9", 2700 | "depd": "~1.1.2", 2701 | "destroy": "~1.0.4", 2702 | "encodeurl": "~1.0.2", 2703 | "escape-html": "~1.0.3", 2704 | "etag": "~1.8.1", 2705 | "fresh": "0.5.2", 2706 | "http-errors": "~1.7.2", 2707 | "mime": "1.6.0", 2708 | "ms": "2.1.1", 2709 | "on-finished": "~2.3.0", 2710 | "range-parser": "~1.2.1", 2711 | "statuses": "~1.5.0" 2712 | }, 2713 | "dependencies": { 2714 | "debug": { 2715 | "version": "2.6.9", 2716 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2717 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2718 | "requires": { 2719 | "ms": "2.0.0" 2720 | }, 2721 | "dependencies": { 2722 | "ms": { 2723 | "version": "2.0.0", 2724 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2725 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2726 | } 2727 | } 2728 | }, 2729 | "mime": { 2730 | "version": "1.6.0", 2731 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2732 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 2733 | }, 2734 | "ms": { 2735 | "version": "2.1.1", 2736 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2737 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 2738 | } 2739 | } 2740 | }, 2741 | "serve-favicon": { 2742 | "version": "2.5.0", 2743 | "resolved": "https://registry.npmjs.org/serve-favicon/-/serve-favicon-2.5.0.tgz", 2744 | "integrity": "sha1-k10kDN/g9YBTB/3+ln2IlCosvPA=", 2745 | "requires": { 2746 | "etag": "~1.8.1", 2747 | "fresh": "0.5.2", 2748 | "ms": "2.1.1", 2749 | "parseurl": "~1.3.2", 2750 | "safe-buffer": "5.1.1" 2751 | }, 2752 | "dependencies": { 2753 | "ms": { 2754 | "version": "2.1.1", 2755 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2756 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 2757 | }, 2758 | "safe-buffer": { 2759 | "version": "5.1.1", 2760 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 2761 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 2762 | } 2763 | } 2764 | }, 2765 | "serve-static": { 2766 | "version": "1.14.1", 2767 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 2768 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 2769 | "requires": { 2770 | "encodeurl": "~1.0.2", 2771 | "escape-html": "~1.0.3", 2772 | "parseurl": "~1.3.3", 2773 | "send": "0.17.1" 2774 | } 2775 | }, 2776 | "set-blocking": { 2777 | "version": "2.0.0", 2778 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2779 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 2780 | }, 2781 | "setprototypeof": { 2782 | "version": "1.1.1", 2783 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 2784 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 2785 | }, 2786 | "shebang-command": { 2787 | "version": "2.0.0", 2788 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2789 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2790 | "dev": true, 2791 | "requires": { 2792 | "shebang-regex": "^3.0.0" 2793 | } 2794 | }, 2795 | "shebang-regex": { 2796 | "version": "3.0.0", 2797 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2798 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2799 | "dev": true 2800 | }, 2801 | "sift": { 2802 | "version": "7.0.1", 2803 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 2804 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 2805 | }, 2806 | "signal-exit": { 2807 | "version": "3.0.2", 2808 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2809 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 2810 | }, 2811 | "simple-concat": { 2812 | "version": "1.0.0", 2813 | "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.0.tgz", 2814 | "integrity": "sha1-c0TLuLbib7J9ZrL8hvn21Zl1IcY=" 2815 | }, 2816 | "simple-get": { 2817 | "version": "3.1.0", 2818 | "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-3.1.0.tgz", 2819 | "integrity": "sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA==", 2820 | "requires": { 2821 | "decompress-response": "^4.2.0", 2822 | "once": "^1.3.1", 2823 | "simple-concat": "^1.0.0" 2824 | } 2825 | }, 2826 | "sliced": { 2827 | "version": "1.0.1", 2828 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 2829 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 2830 | }, 2831 | "sparse-bitfield": { 2832 | "version": "3.0.3", 2833 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 2834 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 2835 | "optional": true, 2836 | "requires": { 2837 | "memory-pager": "^1.0.2" 2838 | } 2839 | }, 2840 | "sprintf-js": { 2841 | "version": "1.0.3", 2842 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2843 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2844 | "dev": true 2845 | }, 2846 | "statuses": { 2847 | "version": "1.5.0", 2848 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2849 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 2850 | }, 2851 | "string-width": { 2852 | "version": "2.1.1", 2853 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2854 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2855 | "requires": { 2856 | "is-fullwidth-code-point": "^2.0.0", 2857 | "strip-ansi": "^4.0.0" 2858 | } 2859 | }, 2860 | "string.prototype.trimleft": { 2861 | "version": "2.1.1", 2862 | "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.1.tgz", 2863 | "integrity": "sha512-iu2AGd3PuP5Rp7x2kEZCrB2Nf41ehzh+goo8TV7z8/XDBbsvc6HQIlUl9RjkZ4oyrW1XM5UwlGl1oVEaDjg6Ag==", 2864 | "dev": true, 2865 | "requires": { 2866 | "define-properties": "^1.1.3", 2867 | "function-bind": "^1.1.1" 2868 | } 2869 | }, 2870 | "string.prototype.trimright": { 2871 | "version": "2.1.1", 2872 | "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.1.tgz", 2873 | "integrity": "sha512-qFvWL3/+QIgZXVmJBfpHmxLB7xsUXz6HsUmP8+5dRaC3Q7oKUv9Vo6aMCRZC1smrtyECFsIT30PqBJ1gTjAs+g==", 2874 | "dev": true, 2875 | "requires": { 2876 | "define-properties": "^1.1.3", 2877 | "function-bind": "^1.1.1" 2878 | } 2879 | }, 2880 | "string_decoder": { 2881 | "version": "1.1.1", 2882 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2883 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2884 | "requires": { 2885 | "safe-buffer": "~5.1.0" 2886 | }, 2887 | "dependencies": { 2888 | "safe-buffer": { 2889 | "version": "5.1.2", 2890 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2891 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2892 | } 2893 | } 2894 | }, 2895 | "strip-ansi": { 2896 | "version": "4.0.0", 2897 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2898 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2899 | "requires": { 2900 | "ansi-regex": "^3.0.0" 2901 | } 2902 | }, 2903 | "strip-json-comments": { 2904 | "version": "2.0.1", 2905 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2906 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 2907 | }, 2908 | "superagent": { 2909 | "version": "3.8.3", 2910 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-3.8.3.tgz", 2911 | "integrity": "sha512-GLQtLMCoEIK4eDv6OGtkOoSMt3D+oq0y3dsxMuYuDvaNUvuT8eFBuLmfR0iYYzHC1e8hpzC6ZsxbuP6DIalMFA==", 2912 | "dev": true, 2913 | "requires": { 2914 | "component-emitter": "^1.2.0", 2915 | "cookiejar": "^2.1.0", 2916 | "debug": "^3.1.0", 2917 | "extend": "^3.0.0", 2918 | "form-data": "^2.3.1", 2919 | "formidable": "^1.2.0", 2920 | "methods": "^1.1.1", 2921 | "mime": "^1.4.1", 2922 | "qs": "^6.5.1", 2923 | "readable-stream": "^2.3.5" 2924 | }, 2925 | "dependencies": { 2926 | "debug": { 2927 | "version": "3.2.6", 2928 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 2929 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 2930 | "dev": true, 2931 | "requires": { 2932 | "ms": "^2.1.1" 2933 | } 2934 | }, 2935 | "ms": { 2936 | "version": "2.1.2", 2937 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2938 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2939 | "dev": true 2940 | }, 2941 | "process-nextick-args": { 2942 | "version": "2.0.1", 2943 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2944 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2945 | "dev": true 2946 | }, 2947 | "readable-stream": { 2948 | "version": "2.3.7", 2949 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 2950 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 2951 | "dev": true, 2952 | "requires": { 2953 | "core-util-is": "~1.0.0", 2954 | "inherits": "~2.0.3", 2955 | "isarray": "~1.0.0", 2956 | "process-nextick-args": "~2.0.0", 2957 | "safe-buffer": "~5.1.1", 2958 | "string_decoder": "~1.1.1", 2959 | "util-deprecate": "~1.0.1" 2960 | } 2961 | }, 2962 | "safe-buffer": { 2963 | "version": "5.1.2", 2964 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2965 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2966 | "dev": true 2967 | }, 2968 | "string_decoder": { 2969 | "version": "1.1.1", 2970 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2971 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2972 | "dev": true, 2973 | "requires": { 2974 | "safe-buffer": "~5.1.0" 2975 | } 2976 | } 2977 | } 2978 | }, 2979 | "supertest": { 2980 | "version": "4.0.2", 2981 | "resolved": "https://registry.npmjs.org/supertest/-/supertest-4.0.2.tgz", 2982 | "integrity": "sha512-1BAbvrOZsGA3YTCWqbmh14L0YEq0EGICX/nBnfkfVJn7SrxQV1I3pMYjSzG9y/7ZU2V9dWqyqk2POwxlb09duQ==", 2983 | "dev": true, 2984 | "requires": { 2985 | "methods": "^1.1.2", 2986 | "superagent": "^3.8.3" 2987 | } 2988 | }, 2989 | "supports-color": { 2990 | "version": "6.0.0", 2991 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 2992 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 2993 | "dev": true, 2994 | "requires": { 2995 | "has-flag": "^3.0.0" 2996 | } 2997 | }, 2998 | "tar-fs": { 2999 | "version": "2.0.0", 3000 | "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.0.0.tgz", 3001 | "integrity": "sha512-vaY0obB6Om/fso8a8vakQBzwholQ7v5+uy+tF3Ozvxv1KNezmVQAiWtcNmMHFSFPqL3dJA8ha6gdtFbfX9mcxA==", 3002 | "requires": { 3003 | "chownr": "^1.1.1", 3004 | "mkdirp": "^0.5.1", 3005 | "pump": "^3.0.0", 3006 | "tar-stream": "^2.0.0" 3007 | } 3008 | }, 3009 | "tar-stream": { 3010 | "version": "2.1.2", 3011 | "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.1.2.tgz", 3012 | "integrity": "sha512-UaF6FoJ32WqALZGOIAApXx+OdxhekNMChu6axLJR85zMMjXKWFGjbIRe+J6P4UnRGg9rAwWvbTT0oI7hD/Un7Q==", 3013 | "requires": { 3014 | "bl": "^4.0.1", 3015 | "end-of-stream": "^1.4.1", 3016 | "fs-constants": "^1.0.0", 3017 | "inherits": "^2.0.3", 3018 | "readable-stream": "^3.1.1" 3019 | }, 3020 | "dependencies": { 3021 | "bl": { 3022 | "version": "4.0.2", 3023 | "resolved": "https://registry.npmjs.org/bl/-/bl-4.0.2.tgz", 3024 | "integrity": "sha512-j4OH8f6Qg2bGuWfRiltT2HYGx0e1QcBTrK9KAHNMwMZdQnDZFk0ZSYIpADjYCB3U12nicC5tVJwSIhwOWjb4RQ==", 3025 | "requires": { 3026 | "buffer": "^5.5.0", 3027 | "inherits": "^2.0.4", 3028 | "readable-stream": "^3.4.0" 3029 | } 3030 | }, 3031 | "readable-stream": { 3032 | "version": "3.6.0", 3033 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 3034 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 3035 | "requires": { 3036 | "inherits": "^2.0.3", 3037 | "string_decoder": "^1.1.1", 3038 | "util-deprecate": "^1.0.1" 3039 | } 3040 | } 3041 | } 3042 | }, 3043 | "tmp": { 3044 | "version": "0.1.0", 3045 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.1.0.tgz", 3046 | "integrity": "sha512-J7Z2K08jbGcdA1kkQpJSqLF6T0tdQqpR2pnSUXsIchbPdTI9v3e85cLW0d6WDhwuAleOV71j2xWs8qMPfK7nKw==", 3047 | "dev": true, 3048 | "requires": { 3049 | "rimraf": "^2.6.3" 3050 | } 3051 | }, 3052 | "to-fast-properties": { 3053 | "version": "1.0.3", 3054 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", 3055 | "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=" 3056 | }, 3057 | "to-regex-range": { 3058 | "version": "5.0.1", 3059 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3060 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3061 | "dev": true, 3062 | "requires": { 3063 | "is-number": "^7.0.0" 3064 | } 3065 | }, 3066 | "toidentifier": { 3067 | "version": "1.0.0", 3068 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 3069 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 3070 | }, 3071 | "token-stream": { 3072 | "version": "0.0.1", 3073 | "resolved": "https://registry.npmjs.org/token-stream/-/token-stream-0.0.1.tgz", 3074 | "integrity": "sha1-zu78cXp2xDFvEm0LnbqlXX598Bo=" 3075 | }, 3076 | "tunnel-agent": { 3077 | "version": "0.6.0", 3078 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 3079 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 3080 | "requires": { 3081 | "safe-buffer": "^5.0.1" 3082 | } 3083 | }, 3084 | "twilio": { 3085 | "version": "3.41.1", 3086 | "resolved": "https://registry.npmjs.org/twilio/-/twilio-3.41.1.tgz", 3087 | "integrity": "sha512-YOAuQtb3xELQJDcL+G6ffDRrZeJSlFRph5peudFYcEa9Or5R0x+r8lShXlYl7yP8w7atCWxETSeySLuStEpvhg==", 3088 | "requires": { 3089 | "@types/express": "^4.17.3", 3090 | "axios": "^0.19.2", 3091 | "dayjs": "^1.8.21", 3092 | "jsonwebtoken": "^8.5.1", 3093 | "lodash": "^4.17.15", 3094 | "q": "2.0.x", 3095 | "qs": "^6.9.1", 3096 | "rootpath": "^0.1.2", 3097 | "scmp": "^2.1.0", 3098 | "url-parse": "^1.4.7", 3099 | "xmlbuilder": "^13.0.2" 3100 | }, 3101 | "dependencies": { 3102 | "qs": { 3103 | "version": "6.9.1", 3104 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.1.tgz", 3105 | "integrity": "sha512-Cxm7/SS/y/Z3MHWSxXb8lIFqgqBowP5JMlTUFyJN88y0SGQhVmZnqFK/PeuMX9LzUyWsqqhNxIyg0jlzq946yA==" 3106 | }, 3107 | "scmp": { 3108 | "version": "2.1.0", 3109 | "resolved": "https://registry.npmjs.org/scmp/-/scmp-2.1.0.tgz", 3110 | "integrity": "sha512-o/mRQGk9Rcer/jEEw/yw4mwo3EU/NvYvp577/Btqrym9Qy5/MdWGBqipbALgd2lrdWTJ5/gqDusxfnQBxOxT2Q==" 3111 | } 3112 | } 3113 | }, 3114 | "type-detect": { 3115 | "version": "1.0.0", 3116 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-1.0.0.tgz", 3117 | "integrity": "sha1-diIXzAbbJY7EiQihKY6LlRIejqI=", 3118 | "dev": true 3119 | }, 3120 | "type-is": { 3121 | "version": "1.6.18", 3122 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 3123 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 3124 | "requires": { 3125 | "media-typer": "0.3.0", 3126 | "mime-types": "~2.1.24" 3127 | } 3128 | }, 3129 | "uglify-js": { 3130 | "version": "2.8.29", 3131 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", 3132 | "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", 3133 | "requires": { 3134 | "source-map": "~0.5.1", 3135 | "uglify-to-browserify": "~1.0.0", 3136 | "yargs": "~3.10.0" 3137 | }, 3138 | "dependencies": { 3139 | "source-map": { 3140 | "version": "0.5.7", 3141 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 3142 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" 3143 | } 3144 | } 3145 | }, 3146 | "uglify-to-browserify": { 3147 | "version": "1.0.2", 3148 | "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", 3149 | "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", 3150 | "optional": true 3151 | }, 3152 | "uid-safe": { 3153 | "version": "2.1.5", 3154 | "resolved": "https://registry.npmjs.org/uid-safe/-/uid-safe-2.1.5.tgz", 3155 | "integrity": "sha512-KPHm4VL5dDXKz01UuEd88Df+KzynaohSL9fBh096KWAxSKZQDI2uBrVqtvRM4rwrIrRRKsdLNML/lnaaVSRioA==", 3156 | "requires": { 3157 | "random-bytes": "~1.0.0" 3158 | } 3159 | }, 3160 | "unpipe": { 3161 | "version": "1.0.0", 3162 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3163 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 3164 | }, 3165 | "url-parse": { 3166 | "version": "1.4.7", 3167 | "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.4.7.tgz", 3168 | "integrity": "sha512-d3uaVyzDB9tQoSXFvuSUNFibTd9zxd2bkVrDRvF5TmvWWQwqE4lgYJ5m+x1DbecWkw+LK4RNl2CU1hHuOKPVlg==", 3169 | "requires": { 3170 | "querystringify": "^2.1.1", 3171 | "requires-port": "^1.0.0" 3172 | } 3173 | }, 3174 | "util-deprecate": { 3175 | "version": "1.0.2", 3176 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3177 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 3178 | }, 3179 | "utils-merge": { 3180 | "version": "1.0.1", 3181 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3182 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3183 | }, 3184 | "uuid": { 3185 | "version": "7.0.3", 3186 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-7.0.3.tgz", 3187 | "integrity": "sha512-DPSke0pXhTZgoF/d+WSt2QaKMCFSfx7QegxEWT+JOuHF5aWrKEn0G+ztjuJg/gG8/ItK+rbPCD/yNv8yyih6Cg==", 3188 | "dev": true 3189 | }, 3190 | "vary": { 3191 | "version": "1.1.2", 3192 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3193 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3194 | }, 3195 | "void-elements": { 3196 | "version": "2.0.1", 3197 | "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-2.0.1.tgz", 3198 | "integrity": "sha1-wGavtYK7HLQSjWDqkjkulNXp2+w=" 3199 | }, 3200 | "weak-map": { 3201 | "version": "1.0.5", 3202 | "resolved": "https://registry.npmjs.org/weak-map/-/weak-map-1.0.5.tgz", 3203 | "integrity": "sha1-eWkVhNmGB/UHC9O3CkDmuyLkAes=" 3204 | }, 3205 | "which": { 3206 | "version": "1.3.1", 3207 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3208 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3209 | "dev": true, 3210 | "requires": { 3211 | "isexe": "^2.0.0" 3212 | } 3213 | }, 3214 | "which-module": { 3215 | "version": "2.0.0", 3216 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 3217 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 3218 | "dev": true 3219 | }, 3220 | "which-pm-runs": { 3221 | "version": "1.0.0", 3222 | "resolved": "https://registry.npmjs.org/which-pm-runs/-/which-pm-runs-1.0.0.tgz", 3223 | "integrity": "sha1-Zws6+8VS4LVd9rd4DKdGFfI60cs=" 3224 | }, 3225 | "wide-align": { 3226 | "version": "1.1.3", 3227 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 3228 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 3229 | "requires": { 3230 | "string-width": "^1.0.2 || 2" 3231 | } 3232 | }, 3233 | "window-size": { 3234 | "version": "0.1.0", 3235 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz", 3236 | "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=" 3237 | }, 3238 | "wrap-ansi": { 3239 | "version": "5.1.0", 3240 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 3241 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 3242 | "dev": true, 3243 | "requires": { 3244 | "ansi-styles": "^3.2.0", 3245 | "string-width": "^3.0.0", 3246 | "strip-ansi": "^5.0.0" 3247 | }, 3248 | "dependencies": { 3249 | "ansi-regex": { 3250 | "version": "4.1.0", 3251 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 3252 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 3253 | "dev": true 3254 | }, 3255 | "string-width": { 3256 | "version": "3.1.0", 3257 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3258 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3259 | "dev": true, 3260 | "requires": { 3261 | "emoji-regex": "^7.0.1", 3262 | "is-fullwidth-code-point": "^2.0.0", 3263 | "strip-ansi": "^5.1.0" 3264 | } 3265 | }, 3266 | "strip-ansi": { 3267 | "version": "5.2.0", 3268 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 3269 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 3270 | "dev": true, 3271 | "requires": { 3272 | "ansi-regex": "^4.1.0" 3273 | } 3274 | } 3275 | } 3276 | }, 3277 | "wrappy": { 3278 | "version": "1.0.2", 3279 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3280 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 3281 | }, 3282 | "xmlbuilder": { 3283 | "version": "13.0.2", 3284 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-13.0.2.tgz", 3285 | "integrity": "sha512-Eux0i2QdDYKbdbA6AM6xE4m6ZTZr4G4xF9kahI2ukSEMCzwce2eX9WlTI5J3s+NU7hpasFsr8hWIONae7LluAQ==" 3286 | }, 3287 | "xmldom": { 3288 | "version": "0.1.31", 3289 | "resolved": "https://registry.npmjs.org/xmldom/-/xmldom-0.1.31.tgz", 3290 | "integrity": "sha512-yS2uJflVQs6n+CyjHoaBmVSqIDevTAWrzMmjG1Gc7h1qQ7uVozNhEPJAwZXWyGQ/Gafo3fCwrcaokezLPupVyQ==", 3291 | "dev": true 3292 | }, 3293 | "xpath": { 3294 | "version": "0.0.24", 3295 | "resolved": "https://registry.npmjs.org/xpath/-/xpath-0.0.24.tgz", 3296 | "integrity": "sha1-Gt4WLhzFI8jTn8fQavwW6iFvKfs=", 3297 | "dev": true 3298 | }, 3299 | "y18n": { 3300 | "version": "4.0.0", 3301 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 3302 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 3303 | "dev": true 3304 | }, 3305 | "yargs": { 3306 | "version": "3.10.0", 3307 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz", 3308 | "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", 3309 | "requires": { 3310 | "camelcase": "^1.0.2", 3311 | "cliui": "^2.1.0", 3312 | "decamelize": "^1.0.0", 3313 | "window-size": "0.1.0" 3314 | } 3315 | }, 3316 | "yargs-parser": { 3317 | "version": "13.1.2", 3318 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 3319 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 3320 | "dev": true, 3321 | "requires": { 3322 | "camelcase": "^5.0.0", 3323 | "decamelize": "^1.2.0" 3324 | }, 3325 | "dependencies": { 3326 | "camelcase": { 3327 | "version": "5.3.1", 3328 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 3329 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 3330 | "dev": true 3331 | } 3332 | } 3333 | }, 3334 | "yargs-unparser": { 3335 | "version": "1.6.0", 3336 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 3337 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 3338 | "dev": true, 3339 | "requires": { 3340 | "flat": "^4.1.0", 3341 | "lodash": "^4.17.15", 3342 | "yargs": "^13.3.0" 3343 | }, 3344 | "dependencies": { 3345 | "ansi-regex": { 3346 | "version": "4.1.0", 3347 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 3348 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 3349 | "dev": true 3350 | }, 3351 | "cliui": { 3352 | "version": "5.0.0", 3353 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 3354 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 3355 | "dev": true, 3356 | "requires": { 3357 | "string-width": "^3.1.0", 3358 | "strip-ansi": "^5.2.0", 3359 | "wrap-ansi": "^5.1.0" 3360 | } 3361 | }, 3362 | "string-width": { 3363 | "version": "3.1.0", 3364 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3365 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3366 | "dev": true, 3367 | "requires": { 3368 | "emoji-regex": "^7.0.1", 3369 | "is-fullwidth-code-point": "^2.0.0", 3370 | "strip-ansi": "^5.1.0" 3371 | } 3372 | }, 3373 | "strip-ansi": { 3374 | "version": "5.2.0", 3375 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 3376 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 3377 | "dev": true, 3378 | "requires": { 3379 | "ansi-regex": "^4.1.0" 3380 | } 3381 | }, 3382 | "yargs": { 3383 | "version": "13.3.2", 3384 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 3385 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 3386 | "dev": true, 3387 | "requires": { 3388 | "cliui": "^5.0.0", 3389 | "find-up": "^3.0.0", 3390 | "get-caller-file": "^2.0.1", 3391 | "require-directory": "^2.1.1", 3392 | "require-main-filename": "^2.0.0", 3393 | "set-blocking": "^2.0.0", 3394 | "string-width": "^3.0.0", 3395 | "which-module": "^2.0.0", 3396 | "y18n": "^4.0.0", 3397 | "yargs-parser": "^13.1.2" 3398 | } 3399 | } 3400 | } 3401 | }, 3402 | "yauzl": { 3403 | "version": "2.10.0", 3404 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 3405 | "integrity": "sha1-x+sXyT4RLLEIb6bY5R+wZnt5pfk=", 3406 | "dev": true, 3407 | "requires": { 3408 | "buffer-crc32": "~0.2.3", 3409 | "fd-slicer": "~1.1.0" 3410 | } 3411 | } 3412 | } 3413 | } 3414 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "airtng-node", 3 | "version": "0.0.0", 4 | "private": true, 5 | "scripts": { 6 | "start": "node ./bin/www", 7 | "test": "node_modules/.bin/mocha spec --exit" 8 | }, 9 | "engines": { 10 | "node": "^12" 11 | }, 12 | "dependencies": { 13 | "body-parser": "^1.19.0", 14 | "connect-flash": "^0.1.1", 15 | "cookie-parser": "~1.3.5", 16 | "debug": "^4.1.1", 17 | "dotenv": "^8.2.0", 18 | "express": "^4.17.1", 19 | "express-session": "^1.12.1", 20 | "kerberos": "~1.1.3", 21 | "mongoose": "^5.9.5", 22 | "mongoose-deep-populate": "^3.1.1", 23 | "morgan": "^1.9.1", 24 | "passport": "^0.3.2", 25 | "passport-local": "^1.0.0", 26 | "passport-local-mongoose": "^3.1.0", 27 | "passport-stub": "^1.0.1", 28 | "pug": "2.0.4", 29 | "serve-favicon": "^2.5.0", 30 | "twilio": "^3.41.1" 31 | }, 32 | "devDependencies": { 33 | "chai": "^3.4.1", 34 | "mocha": "^7.1.1", 35 | "mongodb-memory-server": "^6.5.2", 36 | "supertest": "^4.0.2", 37 | "xmldom": "^0.1.27", 38 | "xpath": "0.0.24" 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /public/images/airtng-logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/TwilioDevEd/airtng-node/a4ec066ba881e99782c79bea65ef6764bc5d0e38/public/images/airtng-logo.png -------------------------------------------------------------------------------- /public/images/spock.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/TwilioDevEd/airtng-node/a4ec066ba881e99782c79bea65ef6764bc5d0e38/public/images/spock.png -------------------------------------------------------------------------------- /public/images/tngbg.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/TwilioDevEd/airtng-node/a4ec066ba881e99782c79bea65ef6764bc5d0e38/public/images/tngbg.jpg -------------------------------------------------------------------------------- /public/stylesheets/app.css: -------------------------------------------------------------------------------- 1 | @import url(http://fonts.googleapis.com/css?family=Raleway:400,600,300); 2 | 3 | html { 4 | box-sizing:border-box; 5 | } 6 | 7 | body { 8 | font-family: 'Raleway', sans-serif; 9 | } 10 | 11 | *, *:before, *:after { 12 | box-sizing:inherit; 13 | } 14 | 15 | a:visited { 16 | color:white; 17 | } 18 | 19 | footer { 20 | font-size:12px; 21 | color:#787878; 22 | margin-top:20px; 23 | padding-top:20px; 24 | text-align:center; 25 | } 26 | 27 | footer i { 28 | color:#ff0000; 29 | } 30 | 31 | nav a:focus { 32 | text-decoration:none; 33 | color:#337ab7; 34 | } 35 | 36 | td { 37 | padding:10px; 38 | } 39 | 40 | #main { 41 | margin-top:10px; 42 | } 43 | 44 | #messages p { 45 | padding:10px; 46 | border:1px solid #eee; 47 | } 48 | 49 | #messages i { 50 | float:right; 51 | margin-left:5px; 52 | cursor:pointer; 53 | } 54 | 55 | #countries-input-0{ 56 | display: block; 57 | width: 100%; 58 | height: 34px; 59 | padding: 6px 12px; 60 | font-size: 14px; 61 | line-height: 1.42857; 62 | color: #555; 63 | background-color: #FFF; 64 | background-image: none; 65 | border: 1px solid #CCC; 66 | border-radius: 4px; 67 | box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.075) inset; 68 | transition: border-color 0.15s ease-in-out 0s, box-shadow 0.15s ease-in-out 0s; 69 | } 70 | 71 | -------------------------------------------------------------------------------- /public/stylesheets/main.css: -------------------------------------------------------------------------------- 1 | body.cover footer { 2 | text-align: center; 3 | position: absolute; 4 | bottom: 20px; 5 | width: 100%; 6 | } 7 | 8 | .hero-text { 9 | background: url('/images/tngbg.jpg'); 10 | margin: 0px; 11 | top: 0px; 12 | text-align: center; 13 | padding: 130px; 14 | color: white; 15 | background-size: cover; 16 | } 17 | 18 | .hero-text.full-page { 19 | height: 100%; 20 | position: absolute; 21 | width: 100%; 22 | } 23 | 24 | .hero-text h1 { 25 | font-size: 60px; 26 | text-transform: uppercase; 27 | } 28 | 29 | .hero-text p { 30 | font-size: 30px; 31 | } 32 | 33 | .hero-text .btn-transparent { 34 | background: rgba(255, 255, 255, 0.6); 35 | margin: 30px; 36 | color: white; 37 | font-weight: 600; 38 | letter-spacing: 1px; 39 | } 40 | 41 | .navbar { 42 | border-radius: 0px !important; 43 | } 44 | 45 | .navbar.navbar-transparent { 46 | background: transparent; 47 | position: absolute; 48 | width: 100%; 49 | top: 0px; 50 | z-index: 1020; 51 | padding: 20px; 52 | } 53 | 54 | .navbar.navbar-space { 55 | background: url('/images/tngbg.jpg'); 56 | height: 90px; 57 | } 58 | 59 | .navbar .navbar-brand { 60 | background: url('/images/airtng-logo.png') no-repeat; 61 | padding-left: 40px; 62 | color: white; 63 | font-size: 32px; 64 | } 65 | 66 | .navbar img { 67 | width: 20px; 68 | } 69 | 70 | .navbar li { 71 | list-style: none; 72 | margin: 10px; 73 | } 74 | 75 | .navbar li a { 76 | color: #337ab7 !important; 77 | font-size: 14px; 78 | } 79 | 80 | .navbar li a:hover { 81 | background: transparent; 82 | text-decoration: none; 83 | } 84 | 85 | .navbar li a:visited { 86 | color: #337ab7 !important; 87 | } 88 | 89 | #main.push-hero { 90 | margin-top: 30px; 91 | } 92 | 93 | #main.push-nav { 94 | margin-top: 60px; 95 | } 96 | -------------------------------------------------------------------------------- /public/stylesheets/properties.css: -------------------------------------------------------------------------------- 1 | body.property-page footer { 2 | position: relative; 3 | } 4 | 5 | body.property-page #main { 6 | min-height: 900px; 7 | } 8 | 9 | .property { 10 | display: block; 11 | position: relative; 12 | border-radius: 10px; 13 | text-align: center; 14 | padding-top: 88px; 15 | height: 240px; 16 | text-transform: uppercase; 17 | overflow: hidden; 18 | margin-bottom: 20px; 19 | } 20 | 21 | .property img { 22 | vertical-align: middle; 23 | width: 100%; 24 | position: absolute; 25 | left: 0px; 26 | top: 0px; 27 | border-radius: 10px; 28 | } 29 | 30 | .property h2 { 31 | color: white; 32 | z-index: 1000; 33 | position: relative; 34 | } 35 | 36 | .property-detail { 37 | position: absolute; 38 | top: 0px; 39 | width: 100%; 40 | } 41 | 42 | .property-detail .overview { 43 | height: 400px; 44 | overflow: hidden; 45 | } 46 | 47 | .property-detail img { 48 | width: 100%; 49 | } 50 | 51 | -------------------------------------------------------------------------------- /public/stylesheets/scaffolds.css: -------------------------------------------------------------------------------- 1 | body { 2 | background-color: #fff; 3 | color: #333; 4 | font-family: verdana, arial, helvetica, sans-serif; 5 | font-size: 13px; 6 | line-height: 18px; 7 | } 8 | 9 | p, ol, ul, td { 10 | font-family: verdana, arial, helvetica, sans-serif; 11 | font-size: 13px; 12 | line-height: 18px; 13 | } 14 | 15 | pre { 16 | background-color: #eee; 17 | padding: 10px; 18 | font-size: 11px; 19 | } 20 | 21 | a { 22 | color: #000; 23 | } 24 | 25 | a:visited { 26 | color: #666; 27 | } 28 | 29 | a:hover { 30 | color: #fff; 31 | background-color: #000; 32 | } 33 | 34 | div.field, div.actions { 35 | margin-bottom: 10px; 36 | } 37 | 38 | #notice { 39 | color: green; 40 | } 41 | 42 | .field_with_errors { 43 | padding: 2px; 44 | background-color: red; 45 | display: table; 46 | } 47 | 48 | #error_explanation { 49 | width: 450px; 50 | border: 2px solid red; 51 | padding: 7px; 52 | padding-bottom: 0; 53 | margin-bottom: 20px; 54 | background-color: #f0f0f0; 55 | } 56 | 57 | #error_explanation h2 { 58 | text-align: left; 59 | font-weight: bold; 60 | padding: 5px 5px 5px 15px; 61 | font-size: 12px; 62 | margin: -7px; 63 | margin-bottom: 0px; 64 | background-color: #c00; 65 | color: #fff; 66 | } 67 | 68 | #error_explanation ul li { 69 | font-size: 12px; 70 | list-style: square; 71 | } 72 | 73 | -------------------------------------------------------------------------------- /routes/index.js: -------------------------------------------------------------------------------- 1 | var express = require('express'); 2 | var router = express.Router(); 3 | 4 | /* GET home page. */ 5 | router.get('/', function(req, res, next) { 6 | res.render('index', { user: req.user }); 7 | }); 8 | 9 | module.exports = router; 10 | -------------------------------------------------------------------------------- /routes/properties.js: -------------------------------------------------------------------------------- 1 | var express = require('express'); 2 | var router = express.Router(); 3 | var Property = require('../models/property'); 4 | var middleware = require('../lib/middleware'); 5 | 6 | router.use(function (req, res, next) { 7 | res.locals.user = req.user; 8 | next(); 9 | }); 10 | 11 | // GET /properties 12 | router.get('/', function (req, res) { 13 | Property.find().then(function (properties) { 14 | res.render('properties/index', { properties: properties }); 15 | }); 16 | }); 17 | 18 | // GET /properties/new 19 | router.get('/new', middleware.isAuthenticated, function (req, res) { 20 | Property.find().then(function (properties) { 21 | res.render('properties/new'); 22 | }); 23 | }); 24 | 25 | // GET /properties/1 26 | router.get('/:id', middleware.isAuthenticated, function (req, res) { 27 | var propertyId = req.params.id; 28 | Property.findOne({ _id: propertyId }).then(function (property) { 29 | res.render('properties/show', { property: property }); 30 | }); 31 | }); 32 | 33 | // POST /properties 34 | router.post('/', middleware.isAuthenticated, function (req, res) { 35 | var description = req.body.description; 36 | var imageUrl = req.body.imageUrl; 37 | var user = req.user; 38 | 39 | var property = new Property({ description: description, imageUrl: imageUrl, owner: user.id }); 40 | property.save() 41 | .then(function (savedProperty) { 42 | res.redirect('/properties/' + savedProperty.id); 43 | }); 44 | }); 45 | 46 | // GET /properties/1/edit 47 | router.get('/:id/edit', middleware.isAuthenticated, function (req, res) { 48 | var propertyId = req.params.id; 49 | Property.findOne({ _id: propertyId }).then(function (property) { 50 | res.render('properties/edit', { property: property }); 51 | }); 52 | }); 53 | 54 | // POST /properties/update 55 | router.post('/update', middleware.isAuthenticated, function (req, res) { 56 | var propertyId = req.body.propertyId; 57 | 58 | Property.findOne({ _id: propertyId }) 59 | .then(function (property) { 60 | property.description = req.body.description; 61 | property.imageUrl = req.body.imageUrl; 62 | 63 | return property.save(); 64 | }) 65 | .then(function (updatedProperty) { 66 | return res.redirect('/properties/' + updatedProperty.id); 67 | }); 68 | }); 69 | 70 | module.exports = router; 71 | -------------------------------------------------------------------------------- /routes/reservations.js: -------------------------------------------------------------------------------- 1 | var MessagingResponse = require('twilio').twiml.MessagingResponse; 2 | var twilio = require('twilio'); 3 | var express = require('express'); 4 | var router = express.Router(); 5 | var Property = require('../models/property'); 6 | var Reservation = require('../models/reservation'); 7 | var User = require('../models/user'); 8 | var notifier = require('../lib/notifier'); 9 | 10 | // POST: /reservations 11 | router.post('/', function (req, res) { 12 | var propertyId = req.body.propertyId; 13 | var user = req.user; 14 | 15 | Property.findOne({ _id: propertyId }) 16 | .then(function (property) { 17 | var reservation = new Reservation({ 18 | message: req.body.message, 19 | property: propertyId, 20 | guest: user.id 21 | }); 22 | 23 | return reservation.save(); 24 | }) 25 | .then(function () { 26 | notifier.sendNotification(); 27 | res.redirect('/properties'); 28 | }) 29 | .catch(function(err) { 30 | console.log(err); 31 | }); 32 | }); 33 | 34 | // POST: /reservations/handle 35 | router.post('/handle', twilio.webhook({validate: false}), function (req, res) { 36 | var from = req.body.From; 37 | var smsRequest = req.body.Body; 38 | 39 | var smsResponse; 40 | 41 | User.findOne({phoneNumber: from}) 42 | .then(function (host) { 43 | return Reservation.findOne({status: 'pending'}); 44 | }) 45 | .then(function (reservation) { 46 | if (reservation === null) { 47 | throw 'No pending reservations'; 48 | } 49 | reservation.status = smsRequest.toLowerCase() === "accept" ? "confirmed" : "rejected"; 50 | return reservation.save(); 51 | }) 52 | .then(function (reservation) { 53 | var message = "You have successfully " + reservation.status + " the reservation"; 54 | respond(res, message); 55 | }) 56 | .catch(function (err) { 57 | var message = "Sorry, it looks like you do not have any reservations to respond to"; 58 | respond(res, message); 59 | }); 60 | }); 61 | 62 | var respond = function(res, message) { 63 | var messagingResponse = new MessagingResponse(); 64 | messagingResponse.message({}, message); 65 | 66 | res.type('text/xml'); 67 | res.send(messagingResponse.toString()); 68 | } 69 | 70 | module.exports = router; 71 | -------------------------------------------------------------------------------- /routes/sessions.js: -------------------------------------------------------------------------------- 1 | var express = require('express'); 2 | var passport = require('passport'); 3 | 4 | var User = require('../models/user'); 5 | 6 | var router = express.Router(); 7 | 8 | // GET: /sessions/login 9 | router.get('/login', function(req, res) { 10 | res.render('login', { message: req.flash('error') }); 11 | }); 12 | 13 | // POST: /sessions/login 14 | router.post('/login', 15 | passport.authenticate('local', { 16 | successRedirect: '/', 17 | failureRedirect: '/sessions/login', 18 | failureFlash: true 19 | }), function(req, res) { 20 | req.session.save(function (err) { 21 | if (err) { 22 | return next(err); 23 | } 24 | 25 | res.redirect('/'); 26 | }); 27 | }); 28 | 29 | // POST: /sessions/logout 30 | router.get('/logout', function(req, res) { 31 | req.logout(); 32 | req.session.save(function (err) { 33 | if (err) { 34 | console.log(err); 35 | return next(err); 36 | } 37 | res.redirect('/sessions/login'); 38 | }); 39 | }); 40 | 41 | module.exports = router; 42 | -------------------------------------------------------------------------------- /routes/users.js: -------------------------------------------------------------------------------- 1 | var express = require('express'); 2 | var passport = require('passport'); 3 | 4 | var User = require('../models/user'); 5 | 6 | var router = express.Router(); 7 | 8 | // GET: /users/new 9 | router.get('/new', function(req, res) { 10 | res.render('users/new', { message: req.flash('error') }); 11 | }); 12 | 13 | // POST: /users 14 | router.post('/', function(req, res) { 15 | User.register(new User({ 16 | email: req.body.email, 17 | username: req.body.username, 18 | countryCode: req.body.countryCode, 19 | phoneNumber: req.body.phoneNumber 20 | }), req.body.password, function(err, user) { 21 | if (err) { 22 | req.flash('error', 'Could not register the user') 23 | return res.redirect('/users/new'); 24 | } 25 | 26 | passport.authenticate('local')(req, res, function () { 27 | res.redirect('/'); 28 | }); 29 | }); 30 | }); 31 | 32 | module.exports = router; 33 | -------------------------------------------------------------------------------- /spec/db-handler.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const { MongoMemoryServer } = require('mongodb-memory-server'); 3 | 4 | const mongod = new MongoMemoryServer({instance: {port: 27018, dbName:'accountsecuritytesting'}}); 5 | 6 | module.exports.connect = async () => { 7 | const uri = await mongod.getConnectionString(); 8 | 9 | const mongooseOpts = { 10 | useNewUrlParser: true, 11 | useUnifiedTopology: true 12 | }; 13 | 14 | await mongoose.connect(uri, mongooseOpts); 15 | } 16 | 17 | module.exports.closeDatabase = async () => { 18 | await mongoose.connection.dropDatabase(); 19 | await mongoose.connection.close(); 20 | await mongod.stop(); 21 | } 22 | 23 | module.exports.clearDatabase = async () => { 24 | const collections = mongoose.connection.collections; 25 | 26 | for (const key in collections) { 27 | const collection = collections[key]; 28 | await collection.deleteMany(); 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /spec/home.spec.js: -------------------------------------------------------------------------------- 1 | var expect = require('chai').expect; 2 | var supertest = require('supertest'); 3 | 4 | var app = require('../app.js'); 5 | 6 | describe('home', function () { 7 | describe('GET /', function () { 8 | it('respond with ok', function (done) { 9 | var agent = supertest(app); 10 | agent 11 | .get('/') 12 | .expect(function (response) { 13 | expect(response.text).to.contain('captain'); 14 | }) 15 | .expect(200, done); 16 | }); 17 | }); 18 | }); 19 | -------------------------------------------------------------------------------- /spec/properties.spec.js: -------------------------------------------------------------------------------- 1 | const dbHandler = require('./db-handler'); 2 | var passport = require('passport'); 3 | var passportStub = require('passport-stub'); 4 | var expect = require('chai').expect; 5 | var supertest = require('supertest'); 6 | 7 | var app = require('../app.js'); 8 | passportStub.install(app); 9 | 10 | var Property = require('../models/property'); 11 | var User = require('../models/user'); 12 | var description = 'vacation-property'; 13 | var imageUrl = 'http://images.com/example.png'; 14 | var agent = supertest(app); 15 | 16 | describe('properties', function () { 17 | before(async () => await dbHandler.connect()); 18 | 19 | after(async () => { 20 | await dbHandler.clearDatabase(); 21 | await dbHandler.closeDatabase() 22 | }); 23 | 24 | beforeEach(function() { 25 | passportStub.login({username: 'Bob'}); 26 | }); 27 | 28 | describe('GET /properties', function () { 29 | it('list all properties', function (done) { 30 | var property = new Property({ description, imageUrl }); 31 | 32 | var result = property.save(); 33 | result.then(function () { 34 | agent 35 | .get('/properties') 36 | .expect(function (response) { 37 | expect(response.text).to.contain(description); 38 | expect(response.text).to.contain(imageUrl); 39 | }) 40 | .expect(200, done); 41 | }); 42 | }); 43 | }); 44 | 45 | describe('GET /properties/new', function () { 46 | it('shows create property form', function (done) { 47 | agent 48 | .get('/properties/new') 49 | .expect(function (response) { 50 | expect(response.text).to.contain('New'); 51 | }) 52 | .expect(200, done); 53 | }); 54 | }); 55 | 56 | describe('POST /properties', function () { 57 | it('creates a property', function (done) { 58 | agent 59 | .post('/properties') 60 | .type('form') 61 | .send({ 62 | description, 63 | imageUrl 64 | }) 65 | .expect(function (response) { 66 | Property.findOne({}).then(function(property) { 67 | expect(property.imageUrl).to.equal(imageUrl); 68 | }); 69 | }) 70 | .expect(302, done); 71 | }); 72 | }); 73 | 74 | describe('GET /properties/:id', function () { 75 | it('shows a single property', function (done) { 76 | var property = new Property({ description, imageUrl }); 77 | 78 | var result = property.save(); 79 | result.then(function () { 80 | agent 81 | .get('/properties/' + property._id) 82 | .expect(function (response) { 83 | expect(response.text).to.contain(description); 84 | expect(response.text).to.contain(imageUrl); 85 | }) 86 | .expect(200, done); 87 | }); 88 | }); 89 | }); 90 | 91 | describe('GET /properties/:id/edit', function () { 92 | it('shows edit property form', function (done) { 93 | var property = new Property({ description, imageUrl }); 94 | 95 | var result = property.save(); 96 | result.then(function () { 97 | agent 98 | .get('/properties/' + property._id + '/edit') 99 | .expect(function (response) { 100 | expect(response.text).to.contain(description); 101 | expect(response.text).to.contain(imageUrl); 102 | }) 103 | .expect(200, done); 104 | }); 105 | }); 106 | }); 107 | 108 | describe('POST /properties/update', function () { 109 | it('update a property', function (done) { 110 | var updatedDescription = 'updated-description'; 111 | new Property({ description, imageUrl }).save() 112 | .then(function (savedProperty) { 113 | agent 114 | .post('/properties/update') 115 | .type('form') 116 | .send({ 117 | propertyId: savedProperty.id, 118 | description: updatedDescription, 119 | imageUrl 120 | }) 121 | .expect(function (response) { 122 | Property.findOne({}).then(function(property) { 123 | expect(property.imageUrl).to.equal(imageUrl); 124 | }); 125 | }) 126 | .expect(302, done); 127 | }); 128 | }); 129 | }); 130 | }); 131 | 132 | var user = new User({ 133 | email: 'me@example.com', 134 | username: 'bob', 135 | password: 's3cr3t', 136 | countryCode: '+1', 137 | phoneNumber: '555-5555' 138 | }); 139 | 140 | var authenticateUser = function() { 141 | user.save() 142 | .then(function () { 143 | agent 144 | .post('/sessions/login') 145 | .type('form') 146 | .send({ 147 | username: user.username, 148 | password: user.password 149 | }) 150 | }); 151 | } 152 | -------------------------------------------------------------------------------- /spec/reservations.spec.js: -------------------------------------------------------------------------------- 1 | const dbHandler = require('./db-handler'); 2 | var expect = require('chai').expect; 3 | var supertest = require('supertest'); 4 | 5 | var app = require('../app.js'); 6 | 7 | var Property = require('../models/property'); 8 | var Reservation = require('../models/reservation'); 9 | var User = require('../models/user'); 10 | var description = 'property'; 11 | var imageUrl = 'http://images.com/example.png'; 12 | var agent = supertest(app); 13 | var xpath = require('xpath'); 14 | var dom = require('xmldom').DOMParser; 15 | 16 | describe('reservations', function () { 17 | before(async () => await dbHandler.connect()); 18 | 19 | after(async () => { 20 | await dbHandler.clearDatabase(); 21 | await dbHandler.closeDatabase() 22 | }); 23 | 24 | describe('POST /reservations', function () { 25 | it ('creates a reservation', function () { 26 | var property = new Property({ description, imageUrl }); 27 | var message = 'message'; 28 | var reservation = new Reservation({message}); 29 | return reservation.save() 30 | .then(function () { 31 | return property.save(); 32 | }) 33 | .then(function (savedProperty) { 34 | return agent 35 | .post('/reservations') 36 | .type('form') 37 | .send({ 38 | message, 39 | propertyId: savedProperty.id 40 | }); 41 | }) 42 | .then(function (response) { 43 | expect(response.status).to.equal(302); 44 | return Reservation.findOne({}); 45 | }) 46 | .then(function(reservation) { 47 | expect(reservation.status).to.equal('pending'); 48 | expect(reservation.message).to.equal(message); 49 | }); 50 | }); 51 | }); 52 | 53 | describe('POST /reservations/handle', function () { 54 | it('creates a reservation and returns TwiML to send a text message', function () { 55 | var user = new User({ 56 | username: 'username', 57 | email: 'bob@example.com', 58 | password: 'password', 59 | countryCode: '+1', 60 | phoneNumber: 'from' 61 | }); 62 | 63 | var property = new Property({ 64 | description: 'description', 65 | imageUrl: 'imageurl', 66 | owner: user._id}); 67 | 68 | var reservation = new Reservation({ 69 | message: 'message' 70 | }); 71 | 72 | return user.save() 73 | .then(function(user) { 74 | return property.save(); 75 | }) 76 | .then(function(property) { 77 | return reservation.save(); 78 | }) 79 | .then(function() { 80 | return agent.post('/reservations/handle') 81 | .type('form') 82 | .send({ 83 | From: 'from', 84 | Body: 'accept' 85 | }); 86 | }) 87 | .then(function (response) { 88 | var doc = new dom().parseFromString(response.text); 89 | var message = xpath.select('//Response/Message', doc)[0].firstChild.data; 90 | 91 | expect(response.status).to.equal(200); 92 | expect(message).to.equal('You have successfully confirmed the reservation') 93 | 94 | return Reservation.findOne({}) 95 | }) 96 | .then(function(reservation) { 97 | expect(reservation.status).to.equal('confirmed'); 98 | expect(reservation.message).to.equal('message'); 99 | }); 100 | }); 101 | }); 102 | }); 103 | -------------------------------------------------------------------------------- /spec/sessions.spec.js: -------------------------------------------------------------------------------- 1 | var expect = require('chai').expect 2 | , supertest = require('supertest') 3 | , mongoose = require('mongoose') 4 | , app = require('../app') 5 | , User = require('../models/user') 6 | 7 | var agent = supertest(app); 8 | 9 | describe('sessions', function () { 10 | describe('GET /sessions/login', function (done) { 11 | var username = 'bob' 12 | , password = 's3cr3t'; 13 | 14 | new User({ 15 | username: username, 16 | email: 'bob@example.com', 17 | password: password, 18 | countryCode: '+1', 19 | phoneNumber: '555 5555' 20 | }) 21 | .save() 22 | .then(function(user) { 23 | agent 24 | .post('/sessions/login') 25 | .send({ username, password }) 26 | .expect(302, done); 27 | }); 28 | }); 29 | }); 30 | -------------------------------------------------------------------------------- /spec/users.spec.js: -------------------------------------------------------------------------------- 1 | const dbHandler = require('./db-handler'); 2 | var expect = require('chai').expect 3 | , supertest = require('supertest') 4 | , app = require('../app') 5 | 6 | var agent = supertest(app); 7 | 8 | describe('users', function () { 9 | before(async () => await dbHandler.connect()); 10 | 11 | after(async () => { 12 | await dbHandler.clearDatabase(); 13 | await dbHandler.closeDatabase() 14 | }); 15 | 16 | describe('GET /users/new', function () { 17 | it('shows registration form', function (done) { 18 | agent 19 | .get('/users/new') 20 | .expect(function (res) { 21 | }) 22 | .expect(200) 23 | .end(function (err, res) { 24 | if (err) { 25 | return done(err); 26 | } 27 | 28 | expect(res.text).to.contain('Sign up'); 29 | done(); 30 | }); 31 | }); 32 | }); 33 | 34 | describe('POST /users', function () { 35 | it('register a new user', function (done) { 36 | agent 37 | .post('/users') 38 | .send({ 39 | username: 'bob', 40 | email: 'bob@example.com', 41 | password: 's3cr3t', 42 | countryCode: '+1', 43 | phoneNumber: '555 5555' 44 | }) 45 | .expect(302) 46 | .end(function (err, res) { 47 | if (err) { 48 | return done(err); 49 | } 50 | 51 | done(); 52 | }); 53 | }); 54 | }); 55 | }); 56 | -------------------------------------------------------------------------------- /views/error.pug: -------------------------------------------------------------------------------- 1 | extends layout 2 | 3 | block content 4 | h1= message 5 | h2= error.status 6 | pre #{error.stack} 7 | -------------------------------------------------------------------------------- /views/index.pug: -------------------------------------------------------------------------------- 1 | extends layout 2 | 3 | block hero 4 | .hero-text.full-page 5 | h1 Lodging fit for a captain 6 | p The Next Generation of vacation rentals. 7 | 8 | a.btn.btn-transparent.btn-lg(href='/properties') View Properties 9 | -------------------------------------------------------------------------------- /views/layout.pug: -------------------------------------------------------------------------------- 1 | doctype html 2 | html 3 | head 4 | title= title 5 | link(rel='stylesheet' href='//maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css') 6 | link(rel='stylesheet' href='//maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.min.css') 7 | link(rel='stylesheet' href='//cdnjs.cloudflare.com/ajax/libs/authy-forms.css/2.2/form.authy.min.css') 8 | 9 | link(rel='stylesheet', href='/stylesheets/main.css') 10 | link(rel='stylesheet', href='/stylesheets/scaffolds.css') 11 | link(rel='stylesheet', href='/stylesheets/properties.css') 12 | link(rel='stylesheet', href='/stylesheets/app.css') 13 | body(class=typeof cssBody === 'undefined' ? 'property-page' : '') 14 | block nav_bg 15 | nav.navbar.navbar-transparent 16 | a.navbar-brand(href='/') airtng 17 | ul.navbar-nav.navbar-right.pull-right 18 | if (user) 19 | li 20 | img(src='/images/spock.png') 21 | li 22 | a(href='/properties/new') New Vacation Property 23 | li 24 | a(href='/sessions/logout') Log Out 25 | else 26 | li 27 | a(href='/users/new') Sign Up 28 | li 29 | a(href='/sessions/login') Log In 30 | 31 | block hero 32 | 33 | section#main.push-nav 34 | block content 35 | 36 | footer 37 | | Made with by your pals @twilio 38 | 39 | script(src='//cdnjs.cloudflare.com/ajax/libs/authy-forms.js/2.2/form.authy.min.js') 40 | 41 | -------------------------------------------------------------------------------- /views/login.pug: -------------------------------------------------------------------------------- 1 | extends layout 2 | 3 | block nav_bg 4 | nav.navbar.navbar-space 5 | 6 | block content 7 | .container 8 | h1 Login in 9 | div #{message} 10 | form(action="/sessions/login",method="post") 11 | .form-group 12 | label User name: 13 | input.form-control(type='text', name="username", required) 14 | .form-group 15 | label Password: 16 | input.form-control(type='password', name="password", required) 17 | button.btn.btn-default(type='submit') Log In 18 | -------------------------------------------------------------------------------- /views/properties/edit.pug: -------------------------------------------------------------------------------- 1 | extends ../layout 2 | 3 | block nav_bg 4 | nav.navbar.navbar-space 5 | 6 | block content 7 | .container 8 | h1 Edit Vacation Property 9 | form(action='/properties/update' method='post') 10 | input(type='hidden' name='propertyId' value=property.id) 11 | .form-group 12 | label Description 13 | input.form-control(type='text' name='description' value=property.description) 14 | 15 | .form-group 16 | label Image URL 17 | input.form-control(type='text' name='imageUrl' value=property.imageUrl) 18 | 19 | .actions 20 | button.btn.btn-lg.btn-primary(type='submit') Update Property 21 | 22 | a(href='/properties/' + property.id) Show | 23 | a(href='/properties') Back 24 | 25 | -------------------------------------------------------------------------------- /views/properties/index.pug: -------------------------------------------------------------------------------- 1 | extends ../layout 2 | 3 | block hero 4 | .hero-text 5 | h1 Lodging fit for a captain 6 | p The Next Generation of vacation rentals. 7 | 8 | block content 9 | p#notice 10 | .container 11 | .row 12 | each property in properties 13 | .col-md-4 14 | a.property(href='/properties/' + property.id) 15 | img(src=property.imageUrl) 16 | h2= property.description 17 | -------------------------------------------------------------------------------- /views/properties/new.pug: -------------------------------------------------------------------------------- 1 | extends ../layout 2 | 3 | block nav_bg 4 | nav.navbar.navbar-space 5 | 6 | block content 7 | .container 8 | h1 New Vacation Property 9 | form(action='/properties' method='post') 10 | .form-group 11 | label Description 12 | input.form-control(type='text' name='description') 13 | 14 | .form-group 15 | label Image URL 16 | input.form-control(type='text' name='imageUrl') 17 | 18 | .actions 19 | button.btn.btn-lg.btn-primary(type='submit') Create Property 20 | 21 | a(href='/') Back 22 | -------------------------------------------------------------------------------- /views/properties/show.pug: -------------------------------------------------------------------------------- 1 | extends ../layout 2 | 3 | block content 4 | p#notice 5 | .property-detail 6 | .overview 7 | img(src=property.imageUrl) 8 | 9 | .container 10 | h1= property.description 11 | if (user.id == property.owner) 12 | span 13 | a(href='/properties/' + property.id + '/edit') Edit 14 | 15 | hr 16 | 17 | .panel.panel-default 18 | .panel-heading 19 | h3.panel-title Make a Reservation 20 | 21 | .panel-body 22 | form(action='/reservations' method='post') 23 | .form-group 24 | label Would you like to say anything to the host? 25 | textarea.form-control( 26 | name='message' 27 | placeholder='Hello! I am hoping to stay in your intergalactic suite...') 28 | input(type='hidden' name='propertyId' value=property.id) 29 | button.btn.btn-primary(type='submit') Reserve Now 30 | -------------------------------------------------------------------------------- /views/users/new.pug: -------------------------------------------------------------------------------- 1 | extends ../layout 2 | 3 | block nav_bg 4 | nav.navbar.navbar-space 5 | 6 | block content 7 | .container 8 | h1 Sign up for Airtng 9 | div #{message} 10 | form(action="/users",method="post") 11 | .form-group 12 | label Tell us your name: 13 | input.form-control(type='text', name="username", placeholder='Zingelbert Bembledack', required) 14 | .form-group 15 | label Enter Your E-mail Address: 16 | input.form-control(type='text', name="email", placeholder='me@mydomain.com', required) 17 | .form-group 18 | label Enter a password: 19 | input.form-control(type='password', name="password", required) 20 | .form-group 21 | label Country code: 22 | input#authy-countries.form-control(type='text', name="countryCode") 23 | .form-group 24 | label Phone number: 25 | input.form-control(type='text', name="phoneNumber", required) 26 | button.btn.btn-primary(type='submit') Sign up 27 | -------------------------------------------------------------------------------- /webhook.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/TwilioDevEd/airtng-node/a4ec066ba881e99782c79bea65ef6764bc5d0e38/webhook.png --------------------------------------------------------------------------------