├── .dockerignore ├── .env.example ├── .gitignore ├── .travis.yml ├── API_DOC.md ├── Dockerfile ├── README.md ├── TUTORIAL.md ├── fly.toml ├── inspectView.png ├── lib ├── app.js ├── models │ └── Character.js ├── routes │ └── characters.js └── utils │ └── connect.js ├── package-lock.json ├── package.json ├── scrapers ├── infoScraper.js ├── nameScraper.js └── utils.js ├── seed.js └── server.js /.dockerignore: -------------------------------------------------------------------------------- 1 | fly.toml 2 | Dockerfile 3 | .dockerignore 4 | node_modules 5 | .git 6 | -------------------------------------------------------------------------------- /.env.example: -------------------------------------------------------------------------------- 1 | MONGODB_URI= 2 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | .env 3 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: "node" 3 | services: mongodb 4 | 5 | -------------------------------------------------------------------------------- /API_DOC.md: -------------------------------------------------------------------------------- 1 | # stranger-things-api 2 | 3 | ## Routes 4 | **GET /api/v1/characters** - get all characters (default 20 per page) 5 | 6 | **GET /api/v1/characters?perPage=${num}?page=${num}** - edit/page through character list 7 | 8 | **GET /api/v1/characters/:id** - get character by their id 9 | 10 | **GET /api/v1/characters/random?count=${num}** - get a random character (default 1) 11 | 12 | **GET /api/v1/characters?name=${string}** - get character by their name 13 | 14 | **GET /api/v1/characters?${query}=${string}** - get character by a specific query string (see options below) 15 | 16 | **queries available:** aliases, otherRelations, affiliation, occupation, residence, appearsInEpisodes, status, gender, eyeColor, born, hairColor, portrayedBy 17 | 18 | ## Character Schema 19 | This is what the data will look like when returned. 20 | ``` 21 | const characterSchema = new mongoose.Schema({ 22 | name: String, 23 | photo: String, 24 | status: String, 25 | born: String, 26 | aliases: { 27 | type: [String], 28 | default: ['unknown'] 29 | }, 30 | otherRelations: { 31 | type: [String], 32 | default: ['unknown'] 33 | }, 34 | affiliation: { 35 | type: [String], 36 | default: ['unknown'] 37 | }, 38 | occupation: { 39 | type: [String], 40 | default: ['unknown'] 41 | }, 42 | residence: { 43 | type: [String], 44 | default: ['unknown'] 45 | }, 46 | gender: String, 47 | eyeColor: String, 48 | hairColor: String, 49 | portrayedBy: String, 50 | appearsInEpisodes: { 51 | type: [String], 52 | default: ['unknown'] 53 | }, 54 | }); 55 | ``` 56 | 57 | ## Example 58 | **GET /api/v1/characters?name=Eleven** 59 | ``` 60 | [ 61 | { 62 | "_id": "5e77d8d2caf0952a9c8499d9", 63 | "aliases": [ 64 | "El", 65 | "011", 66 | "Jane Ives", 67 | "The Weirdo", 68 | "Eleanor", 69 | "Shirley Temple", 70 | "Mage" 71 | ], 72 | "otherRelations": [ 73 | "Mike Wheeler", 74 | "Dustin Henderson", 75 | "Lucas Sinclair", 76 | "Max Mayfield", 77 | "Will Byers", 78 | "Jonathan Byers", 79 | "Benny Hammond", 80 | "Martin Brenner" 81 | ], 82 | "affiliation": [ 83 | "Hawkins National Laboratory", 84 | "Party", 85 | "Ives family", 86 | "Hopper family" 87 | ], 88 | "occupation": [ 89 | "Lab test subject (formerly)" 90 | ], 91 | "residence": [ 92 | "Hawkins, Indiana (1971 - 1985)", 93 | "Byers house (July 1985 - October 1985)", 94 | "Hopper cabin (December 1983 - July 1985)", 95 | "Wheeler basement (November 1983)", 96 | "Hawkins National Laboratory (1971 - November 1983)" 97 | ], 98 | "appearsInEpisodes": [ 99 | "1", 100 | "2", 101 | "3", 102 | "4", 103 | "5", 104 | "6", 105 | "7", 106 | "8", 107 | "9", 108 | "10", 109 | "11", 110 | "12", 111 | "13", 112 | "15", 113 | "16", 114 | "17", 115 | "18", 116 | "19", 117 | "20", 118 | "21", 119 | "22", 120 | "23", 121 | "24", 122 | "25" 123 | ], 124 | "photo": "https://vignette.wikia.nocookie.net/strangerthings8338/images/f/f1/Eleven_S03_portrait.png/revision/latest/scale-to-width-down/286?cb=20190722075442", 125 | "name": "Eleven", 126 | "status": "Alive", 127 | "born": "1971", 128 | "gender": "Female", 129 | "eyeColor": "Brown", 130 | "hairColor": "Brown", 131 | "portrayedBy": "Millie Bobby Brown" 132 | } 133 | ] 134 | ``` 135 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM debian:bullseye as builder 2 | 3 | ARG NODE_VERSION=15.10.0 4 | 5 | RUN apt-get update; apt install -y curl python-is-python3 pkg-config build-essential 6 | RUN curl https://get.volta.sh | bash 7 | ENV VOLTA_HOME /root/.volta 8 | ENV PATH /root/.volta/bin:$PATH 9 | RUN volta install node@${NODE_VERSION} 10 | 11 | ####################################################################### 12 | 13 | RUN mkdir /app 14 | WORKDIR /app 15 | 16 | # NPM will not install any package listed in "devDependencies" when NODE_ENV is set to "production", 17 | # to install all modules: "npm install --production=false". 18 | # Ref: https://docs.npmjs.com/cli/v9/commands/npm-install#description 19 | 20 | ENV NODE_ENV production 21 | 22 | COPY . . 23 | 24 | RUN npm install 25 | FROM debian:bullseye 26 | 27 | LABEL fly_launch_runtime="nodejs" 28 | 29 | COPY --from=builder /root/.volta /root/.volta 30 | COPY --from=builder /app /app 31 | 32 | WORKDIR /app 33 | ENV NODE_ENV production 34 | ENV PATH /root/.volta/bin:$PATH 35 | 36 | CMD [ "npm", "run", "start" ] 37 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # stranger-things-api 2 | Authors > [Paige Gorry](https://github.com/paigeegorry) | 3 | [Kate Dameron](https://github.com/katedam) 4 | 5 | **[stranger-things-api.fly.dev](https://stranger-things-api.fly.dev)** 6 | 7 | --- 8 | 9 | ## #API_Documentation 10 | 11 | Explore our API here: [strangerthingsapi.netlify.app](https://strangerthingsapi.netlify.app/docs) 12 | 13 | ### Routes 14 | **`GET /api/v1/characters`** - get all characters (default 20 per page) 15 | 16 | **`GET /api/v1/characters?perPage=?page=`** - edit/page through character list 17 | 18 | **`GET /api/v1/characters/:id`** - get character by their id 19 | 20 | **`GET /api/v1/characters/random?count=`** - get a random character (default 1) 21 | 22 | **`GET /api/v1/characters?name=`** - get character by their name 23 | 24 | **`GET /api/v1/characters?=`** - get character by a specific query string (see options below) 25 | 26 | **queries available:** aliases, otherRelations, affiliation, occupation, residence, appearsInEpisodes, status, gender, eyeColor, born, hairColor, portrayedBy 27 | 28 | ## Character Schema 29 | This are the type defs for the data returned. 30 | ``` 31 | { 32 | name: String, 33 | photo: String, 34 | status: String, 35 | born: String, 36 | aliases: { 37 | type: [String], 38 | default: ['unknown'] 39 | }, 40 | otherRelations: { 41 | type: [String], 42 | default: ['unknown'] 43 | }, 44 | affiliation: { 45 | type: [String], 46 | default: ['unknown'] 47 | }, 48 | occupation: { 49 | type: [String], 50 | default: ['unknown'] 51 | }, 52 | residence: { 53 | type: [String], 54 | default: ['unknown'] 55 | }, 56 | gender: String, 57 | eyeColor: String, 58 | hairColor: String, 59 | portrayedBy: String, 60 | appearsInEpisodes: { 61 | type: [String], 62 | default: ['unknown'] 63 | }, 64 | } 65 | ``` 66 | 67 | ## Example 68 | **GET /api/v1/characters?name=Eleven** 69 | ``` 70 | [ 71 | { 72 | "_id": "5e77d8d2caf0952a9c8499d9", 73 | "aliases": [ 74 | "El", 75 | "011", 76 | "Jane Ives", 77 | "The Weirdo", 78 | "Eleanor", 79 | "Shirley Temple", 80 | "Mage" 81 | ], 82 | "otherRelations": [ 83 | "Mike Wheeler", 84 | "Dustin Henderson", 85 | "Lucas Sinclair", 86 | "Max Mayfield", 87 | "Will Byers", 88 | "Jonathan Byers", 89 | "Benny Hammond", 90 | "Martin Brenner" 91 | ], 92 | "affiliation": [ 93 | "Hawkins National Laboratory", 94 | "Party", 95 | "Ives family", 96 | "Hopper family" 97 | ], 98 | "occupation": [ 99 | "Lab test subject (formerly)" 100 | ], 101 | "residence": [ 102 | "Hawkins, Indiana (1971 - 1985)", 103 | "Byers house (July 1985 - October 1985)", 104 | "Hopper cabin (December 1983 - July 1985)", 105 | "Wheeler basement (November 1983)", 106 | "Hawkins National Laboratory (1971 - November 1983)" 107 | ], 108 | "appearsInEpisodes": [ 109 | "1", 110 | "2", 111 | "3", 112 | "4", 113 | "5", 114 | "6", 115 | "7", 116 | "8", 117 | "9", 118 | "10", 119 | "11", 120 | "12", 121 | "13", 122 | "15", 123 | "16", 124 | "17", 125 | "18", 126 | "19", 127 | "20", 128 | "21", 129 | "22", 130 | "23", 131 | "24", 132 | "25" 133 | ], 134 | "photo": "https://vignette.wikia.nocookie.net/strangerthings8338/images/f/f1/Eleven_S03_portrait.png/revision/latest/scale-to-width-down/286?cb=20190722075442", 135 | "name": "Eleven", 136 | "status": "Alive", 137 | "born": "1971", 138 | "gender": "Female", 139 | "eyeColor": "Brown", 140 | "hairColor": "Brown", 141 | "portrayedBy": "Millie Bobby Brown" 142 | } 143 | ] 144 | ``` 145 | 146 | **Say hi on Twitter! [@katerj](https://twitter.com/katerj) [@paigeegorry](https://twitter.com/paigeegorry)** 147 | 148 | -------------------------------------------------------------------------------- /TUTORIAL.md: -------------------------------------------------------------------------------- 1 | ## Tutorial 2 | 3 | This project uses Node.js, Express, Superagent, MongoDB, Mongoose, and node-html-parser deployed to Heroku. This tutorial requires some familiarity with Node.js, Express, and MongoDB, but we have linked resources for you as well. Other technologies are available! 4 | 5 | ### Getting set up 6 | 7 | For this project you'll need to set up a Node.js server. We used Express.js but you can use whatever you want! Check out [this tutorial](https://www.guru99.com/node-js-express.html). 8 | 9 | ### Things to consider before scraping: 10 | Think about what you are scraping and how often that data changes. 11 | ###### If you are scraping data for a streaming service (Netflix, Hulu, etc.), think about how often shows are added to those sites. Do you have a schedule for how you want to maintain your API to keep it up to date? How will you maintain versioning on your API? 12 | 13 | ### Step 1: Get set up to scrape some data! 14 | 15 | - You will need a parser package (there are 100s of them available so you can use whatever you want). For this project we used [node-html-parser](https://www.npmjs.com/package/node-html-parser). 16 | - You will also need to install an npm package to help with the request. We used [super-agent](https://www.npmjs.com/package/superagent). 17 | 18 | `> npm install -D node-html-parser superagent` 19 | 20 | - Now make a _scraper.js_ file at the root of your repo 21 | - Add a function to make the initial request 22 | 23 | ``` 24 | const request = require('superagent'); 25 | const { parse } = require('node-html-parser'); 26 | 27 | const scraper = () => { 28 | return request 29 | .get([your url here]) 30 | .then(res => res.text) 31 | .then(parse) 32 | .then(console.log); 33 | }; 34 | 35 | scraper(); 36 | 37 | module.exports = { scraper }; 38 | ``` 39 | 40 | - Now you should be able to run `node scraper.js` and see some html data appear in your console 41 | 42 | ### Step 2: Make a game plan 43 | 44 | Open up your dev tools and inspect the elements that hold the data you need to scrape. In our case, the first thing we needed to do was grab each `h2` header with the class `pi-title`. Here's a screenshot to see what we started with this: 45 | 46 | ![Game Plan](inspectView.png) 47 | 48 | #### First things first 49 | 50 | - We can grab a series of elements like the `h2` by using the `querySelectorAll` method on the html we get back from the parser. To do this we made a helper function. Be sure to look at the documentation for your npm parser to see what kinds of selectors are available. 51 | 52 | ``` 53 | const titlesList = html => html 54 | .querySelectorAll('h2 .pi-title') 55 | .map(node => node.rawText); 56 | ``` 57 | 58 | - add your helper function to your request function 59 | 60 | ``` 61 | const scraper = () => { 62 | return request 63 | .get('url') 64 | .then(res => res.text) 65 | .then(parse) 66 | .then(titlesList) 67 | .then(console.log); 68 | }; 69 | ``` 70 | 71 | run `node scraper.js` again 72 | 73 | At this point you should be able to see the data and start to make decisions about how to grab different elements, run some clean up functions and start to piece it all together to match your db schema. 74 | 75 | ### Step 3: Database 76 | 77 | _We are using [MongoDB](https://docs.mongodb.com/manual/tutorial/getting-started/) with [Mongoose ODM](https://mongoosejs.com/docs/index.html) (object data modeling). The Mongoose documentation is top notch, whereas the MongoDB docs could use some work. Please reference their documentation for more information. **You will need MongoDB set up on your computer to follow along.** This is how we set up our database._ 78 | 79 | #### a. Set up your schema 80 | 81 | Your schema is how you want your data to look in your database. Basically it is a blueprint for MongoDB. Since all of our data is information about the characters of _Stranger Things_ we need a character schema. For each key value pair from our data, we need to specify it's type. i.e. Here is a character we scraped: 82 | 83 | ``` 84 | { 85 | name: 'Eleven' 86 | } 87 | ``` 88 | 89 | So we need to tell Mongoose that we are expecting all character's names to be a _string_. 90 | 91 | Here is a short snippet: 92 | 93 | ``` 94 | // See full file in ./lib/models/Character.js 95 | 96 | const mongoose = require('mongoose'); 97 | 98 | const characterSchema = new mongoose.Schema({ 99 | name: String, 100 | aliases: { 101 | type: [String], 102 | default: ['unknown'] 103 | }, 104 | }); 105 | 106 | module.exports = mongoose.model('Character', characterSchema); 107 | ``` 108 | 109 | You'll notice that 'aliases' has a type `[String]`; this is to specify that all aliases are arrays of strings. 110 | 111 | The default value is for characters that do not have an 'aliases' field. This is an optional field. (There is also an optional 'required' field, which is defaulted to false.) 112 | 113 | #### b. Set up your connection 114 | 115 | 1. You are going to need to connect your application to your database. We also want to listen for on, off, and error events for our connection. Check out our connect.js file. You will see we import and call our event listeners into our server.js file as 116 | 117 | `require('lib/utils/connect.js')();` 118 | 119 | 2. Your local db name should remain private to you. Set up an .env file and store your `MONGODB_URI=` link there. See our `.env.example` file in the root of our project. _Don't forget to add .env to your .gitignore file!_ 120 | 121 | To access your environment variables, you need to run 122 | 123 | ` > npm i dotenv ` 124 | 125 | and add this to the top of your server.js file 126 | 127 | `require('dotenv').config();` 128 | 129 | 3. Try running your server. Remember, first you will need to run `gomongo`. Then run your server.js file. You should be able to see the following log: 130 | 131 | ``` 132 | listening on PORT ${PROCESS.ENV_PORT} 133 | Connection open on mongodb:${PROCESS.ENV_MONGODB_URI} 134 | ``` 135 | 136 | #### c. Seed your database 137 | In order to seed your database, you will need: 138 | ``` 139 | // access to your MONGODB_URI 140 | require('dotenv').config(); 141 | 142 | // connection to your db 143 | require('./lib/utils/connect')(); 144 | 145 | // your scraper function 146 | const scrapeData = require('./scrapers/infoScraper'); 147 | 148 | // your mongoose schema 149 | const Character = require('./lib/Models/Character'); 150 | ``` 151 | 152 | We set all of this up in it's own file in the root of our application. 153 | 154 | ``` 155 | // ./seed.js 156 | 157 | // don't forget to close the connection when finished! 158 | const mongoose = require('mongoose'); 159 | 160 | scrapeData() 161 | .then(chars => Character.create(chars)) 162 | .finally(() => mongoose.connection.close()); 163 | ``` 164 | 165 | To check out your data, we used [Robo3T](https://robomongo.org/), a free, open source MongoDB GUI. Check out their website for documentation on how to download and set this up on your machine. 166 | 167 | #### Step 4: Routes 168 | This section requires some familiarity with [Express Router](http://expressjs.com/en/5x/api.html#router). 169 | 170 | This section will just be a summary of the functionality of each of our routes. 171 | 172 | **Hot Tip** 173 | We recommend thinking of your users and data. What data would your users want? If you have _a lot_ of data, consider pagination as an option. Try and bounce off ideas with other devs to come up with your routes. 174 | 175 | ##### a. Get character by id 176 | 177 | .get('/:id', (req, res, next) => { 178 | Character 179 | .findById(req.params.id) 180 | .select('-__v') 181 | .then(character => res.send(character)) 182 | .catch(next); 183 | }) 184 | 185 | 186 | ##### b. Get random character(s) 187 | Our get route looks very similar here... 188 | 189 | 190 | .get('/random', (req, res, next) => { 191 | const { count = 1 } = req.query; 192 | Character 193 | .getRandom(+count) 194 | .then(character => res.send(character)) 195 | .catch(next); 196 | }) 197 | 198 | You'll notice a custom static called 'getRandom' being used. You can create your own static method in your model schema. Check out the [docs](https://mongoosejs.com/docs/2.7.x/docs/methods-statics.html) to learn more. 199 | 200 | characterSchema.statics.getRandom = function(count) { 201 | return this.aggregate([{ $sample: { size: count }}, {$project: { __v: false}}]); 202 | }; 203 | 204 | ##### c. Get characters + pagination + queries 205 | For our get all characters route, we repurposed it to handle multiple functionalities including pagination and all queries. Check out the source code: 206 | 207 | .get('/', (req, res, next) => { 208 | const { page = 1, perPage = 20, ...search } = req.query; 209 | 210 | const query = Object.entries(search) 211 | .reduce((query, [key, value]) => { 212 | query[key] = new RegExp(value, 'gmi'); 213 | return query; 214 | }, {}); 215 | 216 | Character 217 | .find(query) 218 | .skip(+perPage * (+page - 1)) 219 | .limit(+perPage) 220 | .lean() 221 | .select('-__v') 222 | .then(characters => res.send(characters)) 223 | .catch(next); 224 | }); 225 | 226 | ### Step 5: Deploy! 227 | 228 | We decided to deploy to Heroku! Here are some resources: 229 | * [Deploying NodeJS App](https://devcenter.heroku.com/articles/deploying-nodejs) 230 | * [Deploying with Git](https://devcenter.heroku.com/articles/git) 231 | * [mLab noSQL DB set-up](https://devcenter.heroku.com/articles/mongolab) 232 | 233 | ### Step 6: Document! 234 | 235 | Take the time to document your application either in a README or create a front end! Provide information on your routes and what type of data users will be accessing. 236 | 237 | **Share your APIs with us on Twitter! [@katerj](https://twitter.com/katerj) [@paigeegorry](https://twitter.com/paigeegorry)** 238 | -------------------------------------------------------------------------------- /fly.toml: -------------------------------------------------------------------------------- 1 | # fly.toml file generated for stranger-things-api on 2023-01-15T15:20:43-08:00 2 | 3 | app = "stranger-things-api" 4 | kill_signal = "SIGINT" 5 | kill_timeout = 5 6 | processes = [] 7 | 8 | [env] 9 | 10 | [experimental] 11 | auto_rollback = true 12 | 13 | [[services]] 14 | http_checks = [] 15 | internal_port = 8080 16 | processes = ["app"] 17 | protocol = "tcp" 18 | script_checks = [] 19 | [services.concurrency] 20 | hard_limit = 25 21 | soft_limit = 20 22 | type = "connections" 23 | 24 | [[services.ports]] 25 | force_https = true 26 | handlers = ["http"] 27 | port = 80 28 | 29 | [[services.ports]] 30 | handlers = ["tls", "http"] 31 | port = 443 32 | 33 | [[services.tcp_checks]] 34 | grace_period = "1s" 35 | interval = "15s" 36 | restart_limit = 0 37 | timeout = "2s" 38 | -------------------------------------------------------------------------------- /inspectView.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/api-tutorial/stranger-things-api/47523c95e31ef42c74fbff5680349d2c4a71cc36/inspectView.png -------------------------------------------------------------------------------- /lib/app.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config(); 2 | const express = require('express'); 3 | const app = express(); 4 | const expressGa = require('express-ga-middleware'); 5 | 6 | const cors = require('cors'); 7 | 8 | app.use(express.json()); 9 | app.use(cors()); 10 | app.use(expressGa(process.env.GOOGLE_ID)); 11 | 12 | app.use('/api/v1/characters', require('./routes/characters')); 13 | 14 | module.exports = app; 15 | -------------------------------------------------------------------------------- /lib/models/Character.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | 3 | const characterSchema = new mongoose.Schema({ 4 | name: String, 5 | photo: String, 6 | status: String, 7 | born: String, 8 | aliases: { 9 | type: [String], 10 | default: ['unknown'] 11 | }, 12 | otherRelations: { 13 | type: [String], 14 | default: ['unknown'] 15 | }, 16 | affiliation: { 17 | type: [String], 18 | default: ['unknown'] 19 | }, 20 | occupation: { 21 | type: [String], 22 | default: ['unknown'] 23 | }, 24 | residence: { 25 | type: [String], 26 | default: ['unknown'] 27 | }, 28 | gender: String, 29 | eyeColor: String, 30 | hairColor: String, 31 | portrayedBy: String, 32 | appearsInEpisodes: { 33 | type: [String], 34 | default: ['unknown'] 35 | }, 36 | }); 37 | 38 | characterSchema.statics.getRandom = function(count) { 39 | return this.aggregate([{ $sample: { size: count }}, {$project: { __v: false}}]); 40 | }; 41 | 42 | module.exports = mongoose.model('Character', characterSchema); 43 | -------------------------------------------------------------------------------- /lib/routes/characters.js: -------------------------------------------------------------------------------- 1 | const { Router } = require('express'); 2 | const Character = require('../models/Character'); 3 | 4 | module.exports = Router() 5 | .get('/random', (req, res, next) => { 6 | const { count = 1 } = req.query; 7 | Character 8 | .getRandom(+count) 9 | .then(character => res.send(character)) 10 | .catch(next); 11 | }) 12 | 13 | .get('/:id', (req, res, next) => { 14 | Character 15 | .findById(req.params.id) 16 | .select('-__v') 17 | .then(character => res.send(character)) 18 | .catch(next); 19 | }) 20 | 21 | .get('/', (req, res, next) => { 22 | const { page = 1, perPage = 20, ...search } = req.query; 23 | 24 | const query = Object.entries(search) 25 | .reduce((query, [key, value]) => { 26 | query[key] = new RegExp(value, 'gmi'); 27 | return query; 28 | }, {}); 29 | 30 | Character 31 | .find(query) 32 | .skip(+perPage * (+page - 1)) 33 | .limit(+perPage) 34 | .lean() 35 | .select('-__v') 36 | .then(characters => res.send(characters)) 37 | .catch(next); 38 | }); 39 | -------------------------------------------------------------------------------- /lib/utils/connect.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable no-undef */ 2 | /* eslint-disable no-console*/ 3 | const mongoose = require('mongoose'); 4 | const { parse } = require('url'); 5 | 6 | // Redacting the uri (aka url) takes the username and password out of the uri 7 | function redact(uri) { 8 | const parsedUri = parse(uri); 9 | const authPart = parsedUri.auth ? '****:****@' : ''; 10 | return `${parsedUri.protocol}://${authPart}${parsedUri.host}:${parsedUri.port}${parsedUri.path}`; 11 | } 12 | 13 | // log function logs the console so that you don't have to repeat - don't forget to include the redact function for the dbUri 14 | function log(event, dbUri) { 15 | return function() { 16 | console.log(`Connection ${event} on ${redact(dbUri)}`); 17 | }; 18 | } 19 | 20 | // Export connection events 'on', 'open' and 'close' pass log function as second param to log event and redacted uri 21 | module.exports = (dbUri = process.env.MONGODB_URI) => { 22 | mongoose.connect(dbUri, { useNewUrlParser: true }); 23 | 24 | mongoose.connection.on('open', log('open', dbUri)); 25 | 26 | mongoose.connection.on('error', log('error', dbUri)); 27 | 28 | mongoose.connection.on('close', log('close', dbUri)); 29 | }; 30 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "api-tutorial", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "api-tutorial", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "cors": "^2.8.5", 13 | "dotenv": "^8.2.0", 14 | "express": "^4.17.1", 15 | "express-ga-middleware": "^0.1.6", 16 | "mongoose": "^5.9.2", 17 | "url": "^0.11.0" 18 | }, 19 | "devDependencies": { 20 | "eslint": "^6.7.0", 21 | "node-html-parser": "^1.1.16", 22 | "nodemon": "^2.0.1", 23 | "superagent": "^5.1.1" 24 | } 25 | }, 26 | "node_modules/@babel/code-frame": { 27 | "version": "7.5.5", 28 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", 29 | "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", 30 | "dev": true, 31 | "dependencies": { 32 | "@babel/highlight": "^7.0.0" 33 | } 34 | }, 35 | "node_modules/@babel/highlight": { 36 | "version": "7.5.0", 37 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 38 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 39 | "dev": true, 40 | "dependencies": { 41 | "chalk": "^2.0.0", 42 | "esutils": "^2.0.2", 43 | "js-tokens": "^4.0.0" 44 | } 45 | }, 46 | "node_modules/@babel/highlight/node_modules/chalk": { 47 | "version": "2.4.2", 48 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 49 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 50 | "dev": true, 51 | "dependencies": { 52 | "ansi-styles": "^3.2.1", 53 | "escape-string-regexp": "^1.0.5", 54 | "supports-color": "^5.3.0" 55 | }, 56 | "engines": { 57 | "node": ">=4" 58 | } 59 | }, 60 | "node_modules/@types/bson": { 61 | "version": "4.0.5", 62 | "resolved": "https://registry.npmjs.org/@types/bson/-/bson-4.0.5.tgz", 63 | "integrity": "sha512-vVLwMUqhYJSQ/WKcE60eFqcyuWse5fGH+NMAXHuKrUAPoryq3ATxk5o4bgYNtg5aOM4APVg7Hnb3ASqUYG0PKg==", 64 | "dependencies": { 65 | "@types/node": "*" 66 | } 67 | }, 68 | "node_modules/@types/mongodb": { 69 | "version": "3.6.20", 70 | "resolved": "https://registry.npmjs.org/@types/mongodb/-/mongodb-3.6.20.tgz", 71 | "integrity": "sha512-WcdpPJCakFzcWWD9juKoZbRtQxKIMYF/JIAM4JrNHrMcnJL6/a2NWjXxW7fo9hxboxxkg+icff8d7+WIEvKgYQ==", 72 | "dependencies": { 73 | "@types/bson": "*", 74 | "@types/node": "*" 75 | } 76 | }, 77 | "node_modules/@types/node": { 78 | "version": "18.11.18", 79 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.11.18.tgz", 80 | "integrity": "sha512-DHQpWGjyQKSHj3ebjFI/wRKcqQcdR+MoFBygntYOZytCqNfkd2ZC4ARDJ2DQqhjH5p85Nnd3jhUJIXrszFX/JA==" 81 | }, 82 | "node_modules/abbrev": { 83 | "version": "1.1.1", 84 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 85 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 86 | "dev": true 87 | }, 88 | "node_modules/accepts": { 89 | "version": "1.3.8", 90 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 91 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 92 | "dependencies": { 93 | "mime-types": "~2.1.34", 94 | "negotiator": "0.6.3" 95 | }, 96 | "engines": { 97 | "node": ">= 0.6" 98 | } 99 | }, 100 | "node_modules/acorn": { 101 | "version": "7.1.1", 102 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.1.tgz", 103 | "integrity": "sha512-add7dgA5ppRPxCFJoAGfMDi7PIBXq1RtGo7BhbLaxwrXPOmw8gq48Y9ozT01hUKy9byMjlR20EJhu5zlkErEkg==", 104 | "dev": true, 105 | "bin": { 106 | "acorn": "bin/acorn" 107 | }, 108 | "engines": { 109 | "node": ">=0.4.0" 110 | } 111 | }, 112 | "node_modules/acorn-jsx": { 113 | "version": "5.1.0", 114 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.1.0.tgz", 115 | "integrity": "sha512-tMUqwBWfLFbJbizRmEcWSLw6HnFzfdJs2sOJEOwwtVPMoH/0Ay+E703oZz78VSXZiiDcZrQ5XKjPIUQixhmgVw==", 116 | "dev": true, 117 | "peerDependencies": { 118 | "acorn": "^6.0.0 || ^7.0.0" 119 | } 120 | }, 121 | "node_modules/ajv": { 122 | "version": "6.12.6", 123 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 124 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 125 | "dependencies": { 126 | "fast-deep-equal": "^3.1.1", 127 | "fast-json-stable-stringify": "^2.0.0", 128 | "json-schema-traverse": "^0.4.1", 129 | "uri-js": "^4.2.2" 130 | }, 131 | "funding": { 132 | "type": "github", 133 | "url": "https://github.com/sponsors/epoberezkin" 134 | } 135 | }, 136 | "node_modules/ansi-escapes": { 137 | "version": "4.3.0", 138 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.0.tgz", 139 | "integrity": "sha512-EiYhwo0v255HUL6eDyuLrXEkTi7WwVCLAw+SeOQ7M7qdun1z1pum4DEm/nuqIVbPvi9RPPc9k9LbyBv6H0DwVg==", 140 | "dev": true, 141 | "dependencies": { 142 | "type-fest": "^0.8.1" 143 | }, 144 | "engines": { 145 | "node": ">=8" 146 | } 147 | }, 148 | "node_modules/ansi-regex": { 149 | "version": "5.0.1", 150 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 151 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 152 | "dev": true, 153 | "engines": { 154 | "node": ">=8" 155 | } 156 | }, 157 | "node_modules/ansi-styles": { 158 | "version": "3.2.1", 159 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 160 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 161 | "dev": true, 162 | "dependencies": { 163 | "color-convert": "^1.9.0" 164 | }, 165 | "engines": { 166 | "node": ">=4" 167 | } 168 | }, 169 | "node_modules/anymatch": { 170 | "version": "3.1.3", 171 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 172 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 173 | "dev": true, 174 | "dependencies": { 175 | "normalize-path": "^3.0.0", 176 | "picomatch": "^2.0.4" 177 | }, 178 | "engines": { 179 | "node": ">= 8" 180 | } 181 | }, 182 | "node_modules/argparse": { 183 | "version": "1.0.10", 184 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 185 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 186 | "dev": true, 187 | "dependencies": { 188 | "sprintf-js": "~1.0.2" 189 | } 190 | }, 191 | "node_modules/array-flatten": { 192 | "version": "1.1.1", 193 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 194 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 195 | }, 196 | "node_modules/asn1": { 197 | "version": "0.2.4", 198 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 199 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 200 | "dependencies": { 201 | "safer-buffer": "~2.1.0" 202 | } 203 | }, 204 | "node_modules/assert-plus": { 205 | "version": "1.0.0", 206 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 207 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 208 | "engines": { 209 | "node": ">=0.8" 210 | } 211 | }, 212 | "node_modules/astral-regex": { 213 | "version": "1.0.0", 214 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 215 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 216 | "dev": true, 217 | "engines": { 218 | "node": ">=4" 219 | } 220 | }, 221 | "node_modules/asynckit": { 222 | "version": "0.4.0", 223 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 224 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 225 | }, 226 | "node_modules/aws-sign2": { 227 | "version": "0.7.0", 228 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 229 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 230 | "engines": { 231 | "node": "*" 232 | } 233 | }, 234 | "node_modules/aws4": { 235 | "version": "1.9.1", 236 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.1.tgz", 237 | "integrity": "sha512-wMHVg2EOHaMRxbzgFJ9gtjOOCrI80OHLG14rxi28XwOW8ux6IiEbRCGGGqCtdAIg4FQCbW20k9RsT4y3gJlFug==" 238 | }, 239 | "node_modules/balanced-match": { 240 | "version": "1.0.0", 241 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 242 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 243 | "dev": true 244 | }, 245 | "node_modules/bcrypt-pbkdf": { 246 | "version": "1.0.2", 247 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 248 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 249 | "dependencies": { 250 | "tweetnacl": "^0.14.3" 251 | } 252 | }, 253 | "node_modules/binary-extensions": { 254 | "version": "2.2.0", 255 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 256 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 257 | "dev": true, 258 | "engines": { 259 | "node": ">=8" 260 | } 261 | }, 262 | "node_modules/bl": { 263 | "version": "2.2.1", 264 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 265 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 266 | "dependencies": { 267 | "readable-stream": "^2.3.5", 268 | "safe-buffer": "^5.1.1" 269 | } 270 | }, 271 | "node_modules/bl/node_modules/readable-stream": { 272 | "version": "2.3.7", 273 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 274 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 275 | "dependencies": { 276 | "core-util-is": "~1.0.0", 277 | "inherits": "~2.0.3", 278 | "isarray": "~1.0.0", 279 | "process-nextick-args": "~2.0.0", 280 | "safe-buffer": "~5.1.1", 281 | "string_decoder": "~1.1.1", 282 | "util-deprecate": "~1.0.1" 283 | } 284 | }, 285 | "node_modules/bl/node_modules/safe-buffer": { 286 | "version": "5.1.2", 287 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 288 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 289 | }, 290 | "node_modules/bl/node_modules/string_decoder": { 291 | "version": "1.1.1", 292 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 293 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 294 | "dependencies": { 295 | "safe-buffer": "~5.1.0" 296 | } 297 | }, 298 | "node_modules/bluebird": { 299 | "version": "3.5.1", 300 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 301 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 302 | }, 303 | "node_modules/body-parser": { 304 | "version": "1.20.1", 305 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 306 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 307 | "dependencies": { 308 | "bytes": "3.1.2", 309 | "content-type": "~1.0.4", 310 | "debug": "2.6.9", 311 | "depd": "2.0.0", 312 | "destroy": "1.2.0", 313 | "http-errors": "2.0.0", 314 | "iconv-lite": "0.4.24", 315 | "on-finished": "2.4.1", 316 | "qs": "6.11.0", 317 | "raw-body": "2.5.1", 318 | "type-is": "~1.6.18", 319 | "unpipe": "1.0.0" 320 | }, 321 | "engines": { 322 | "node": ">= 0.8", 323 | "npm": "1.2.8000 || >= 1.4.16" 324 | } 325 | }, 326 | "node_modules/body-parser/node_modules/debug": { 327 | "version": "2.6.9", 328 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 329 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 330 | "dependencies": { 331 | "ms": "2.0.0" 332 | } 333 | }, 334 | "node_modules/body-parser/node_modules/ms": { 335 | "version": "2.0.0", 336 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 337 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 338 | }, 339 | "node_modules/brace-expansion": { 340 | "version": "1.1.11", 341 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 342 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 343 | "dev": true, 344 | "dependencies": { 345 | "balanced-match": "^1.0.0", 346 | "concat-map": "0.0.1" 347 | } 348 | }, 349 | "node_modules/braces": { 350 | "version": "3.0.2", 351 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 352 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 353 | "dev": true, 354 | "dependencies": { 355 | "fill-range": "^7.0.1" 356 | }, 357 | "engines": { 358 | "node": ">=8" 359 | } 360 | }, 361 | "node_modules/bson": { 362 | "version": "1.1.6", 363 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.6.tgz", 364 | "integrity": "sha512-EvVNVeGo4tHxwi8L6bPj3y3itEvStdwvvlojVxxbyYfoaxJ6keLgrTuKdyfEAszFK+H3olzBuafE0yoh0D1gdg==", 365 | "engines": { 366 | "node": ">=0.6.19" 367 | } 368 | }, 369 | "node_modules/bytes": { 370 | "version": "3.1.2", 371 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 372 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 373 | "engines": { 374 | "node": ">= 0.8" 375 | } 376 | }, 377 | "node_modules/call-bind": { 378 | "version": "1.0.2", 379 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 380 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 381 | "dependencies": { 382 | "function-bind": "^1.1.1", 383 | "get-intrinsic": "^1.0.2" 384 | }, 385 | "funding": { 386 | "url": "https://github.com/sponsors/ljharb" 387 | } 388 | }, 389 | "node_modules/callsites": { 390 | "version": "3.1.0", 391 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 392 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 393 | "dev": true, 394 | "engines": { 395 | "node": ">=6" 396 | } 397 | }, 398 | "node_modules/caseless": { 399 | "version": "0.12.0", 400 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 401 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 402 | }, 403 | "node_modules/chardet": { 404 | "version": "0.7.0", 405 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 406 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 407 | "dev": true 408 | }, 409 | "node_modules/chokidar": { 410 | "version": "3.5.3", 411 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 412 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 413 | "dev": true, 414 | "funding": [ 415 | { 416 | "type": "individual", 417 | "url": "https://paulmillr.com/funding/" 418 | } 419 | ], 420 | "dependencies": { 421 | "anymatch": "~3.1.2", 422 | "braces": "~3.0.2", 423 | "glob-parent": "~5.1.2", 424 | "is-binary-path": "~2.1.0", 425 | "is-glob": "~4.0.1", 426 | "normalize-path": "~3.0.0", 427 | "readdirp": "~3.6.0" 428 | }, 429 | "engines": { 430 | "node": ">= 8.10.0" 431 | }, 432 | "optionalDependencies": { 433 | "fsevents": "~2.3.2" 434 | } 435 | }, 436 | "node_modules/cli-cursor": { 437 | "version": "3.1.0", 438 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 439 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 440 | "dev": true, 441 | "dependencies": { 442 | "restore-cursor": "^3.1.0" 443 | }, 444 | "engines": { 445 | "node": ">=8" 446 | } 447 | }, 448 | "node_modules/cli-width": { 449 | "version": "2.2.0", 450 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 451 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 452 | "dev": true 453 | }, 454 | "node_modules/color-convert": { 455 | "version": "1.9.3", 456 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 457 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 458 | "dev": true, 459 | "dependencies": { 460 | "color-name": "1.1.3" 461 | } 462 | }, 463 | "node_modules/color-name": { 464 | "version": "1.1.3", 465 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 466 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 467 | "dev": true 468 | }, 469 | "node_modules/combined-stream": { 470 | "version": "1.0.8", 471 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 472 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 473 | "dependencies": { 474 | "delayed-stream": "~1.0.0" 475 | }, 476 | "engines": { 477 | "node": ">= 0.8" 478 | } 479 | }, 480 | "node_modules/component-emitter": { 481 | "version": "1.3.0", 482 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 483 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", 484 | "dev": true 485 | }, 486 | "node_modules/concat-map": { 487 | "version": "0.0.1", 488 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 489 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 490 | "dev": true 491 | }, 492 | "node_modules/content-disposition": { 493 | "version": "0.5.4", 494 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 495 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 496 | "dependencies": { 497 | "safe-buffer": "5.2.1" 498 | }, 499 | "engines": { 500 | "node": ">= 0.6" 501 | } 502 | }, 503 | "node_modules/content-type": { 504 | "version": "1.0.4", 505 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 506 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 507 | "engines": { 508 | "node": ">= 0.6" 509 | } 510 | }, 511 | "node_modules/cookie": { 512 | "version": "0.5.0", 513 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 514 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 515 | "engines": { 516 | "node": ">= 0.6" 517 | } 518 | }, 519 | "node_modules/cookie-signature": { 520 | "version": "1.0.6", 521 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 522 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 523 | }, 524 | "node_modules/cookiejar": { 525 | "version": "2.1.2", 526 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.2.tgz", 527 | "integrity": "sha512-Mw+adcfzPxcPeI+0WlvRrr/3lGVO0bD75SxX6811cxSh1Wbxx7xZBGK1eVtDf6si8rg2lhnUjsVLMFMfbRIuwA==", 528 | "dev": true 529 | }, 530 | "node_modules/core-util-is": { 531 | "version": "1.0.2", 532 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 533 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 534 | }, 535 | "node_modules/cors": { 536 | "version": "2.8.5", 537 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 538 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 539 | "dependencies": { 540 | "object-assign": "^4", 541 | "vary": "^1" 542 | }, 543 | "engines": { 544 | "node": ">= 0.10" 545 | } 546 | }, 547 | "node_modules/cross-spawn": { 548 | "version": "6.0.5", 549 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 550 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 551 | "dev": true, 552 | "dependencies": { 553 | "nice-try": "^1.0.4", 554 | "path-key": "^2.0.1", 555 | "semver": "^5.5.0", 556 | "shebang-command": "^1.2.0", 557 | "which": "^1.2.9" 558 | }, 559 | "engines": { 560 | "node": ">=4.8" 561 | } 562 | }, 563 | "node_modules/cross-spawn/node_modules/semver": { 564 | "version": "5.7.1", 565 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 566 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 567 | "dev": true, 568 | "bin": { 569 | "semver": "bin/semver" 570 | } 571 | }, 572 | "node_modules/dashdash": { 573 | "version": "1.14.1", 574 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 575 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 576 | "dependencies": { 577 | "assert-plus": "^1.0.0" 578 | }, 579 | "engines": { 580 | "node": ">=0.10" 581 | } 582 | }, 583 | "node_modules/debug": { 584 | "version": "4.1.1", 585 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 586 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 587 | "deprecated": "Debug versions >=3.2.0 <3.2.7 || >=4 <4.3.1 have a low-severity ReDos regression when used in a Node.js environment. It is recommended you upgrade to 3.2.7 or 4.3.1. (https://github.com/visionmedia/debug/issues/797)", 588 | "dev": true, 589 | "dependencies": { 590 | "ms": "^2.1.1" 591 | } 592 | }, 593 | "node_modules/deep-is": { 594 | "version": "0.1.3", 595 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 596 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 597 | "dev": true 598 | }, 599 | "node_modules/delayed-stream": { 600 | "version": "1.0.0", 601 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 602 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 603 | "engines": { 604 | "node": ">=0.4.0" 605 | } 606 | }, 607 | "node_modules/denque": { 608 | "version": "1.5.1", 609 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.5.1.tgz", 610 | "integrity": "sha512-XwE+iZ4D6ZUB7mfYRMb5wByE8L74HCn30FBN7sWnXksWc1LO1bPDl67pBR9o/kC4z/xSNAwkMYcGgqDV3BE3Hw==", 611 | "engines": { 612 | "node": ">=0.10" 613 | } 614 | }, 615 | "node_modules/depd": { 616 | "version": "2.0.0", 617 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 618 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 619 | "engines": { 620 | "node": ">= 0.8" 621 | } 622 | }, 623 | "node_modules/destroy": { 624 | "version": "1.2.0", 625 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 626 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 627 | "engines": { 628 | "node": ">= 0.8", 629 | "npm": "1.2.8000 || >= 1.4.16" 630 | } 631 | }, 632 | "node_modules/doctrine": { 633 | "version": "3.0.0", 634 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 635 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 636 | "dev": true, 637 | "dependencies": { 638 | "esutils": "^2.0.2" 639 | }, 640 | "engines": { 641 | "node": ">=6.0.0" 642 | } 643 | }, 644 | "node_modules/dotenv": { 645 | "version": "8.2.0", 646 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 647 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==", 648 | "engines": { 649 | "node": ">=8" 650 | } 651 | }, 652 | "node_modules/ecc-jsbn": { 653 | "version": "0.1.2", 654 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 655 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 656 | "dependencies": { 657 | "jsbn": "~0.1.0", 658 | "safer-buffer": "^2.1.0" 659 | } 660 | }, 661 | "node_modules/ee-first": { 662 | "version": "1.1.1", 663 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 664 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 665 | }, 666 | "node_modules/emoji-regex": { 667 | "version": "8.0.0", 668 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 669 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 670 | "dev": true 671 | }, 672 | "node_modules/encodeurl": { 673 | "version": "1.0.2", 674 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 675 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 676 | "engines": { 677 | "node": ">= 0.8" 678 | } 679 | }, 680 | "node_modules/escape-html": { 681 | "version": "1.0.3", 682 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 683 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 684 | }, 685 | "node_modules/escape-string-regexp": { 686 | "version": "1.0.5", 687 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 688 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 689 | "dev": true, 690 | "engines": { 691 | "node": ">=0.8.0" 692 | } 693 | }, 694 | "node_modules/eslint": { 695 | "version": "6.7.0", 696 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.7.0.tgz", 697 | "integrity": "sha512-dQpj+PaHKHfXHQ2Imcw5d853PTvkUGbHk/MR68KQUl98EgKDCdh4vLRH1ZxhqeQjQFJeg8fgN0UwmNhN3l8dDQ==", 698 | "dev": true, 699 | "dependencies": { 700 | "@babel/code-frame": "^7.0.0", 701 | "ajv": "^6.10.0", 702 | "chalk": "^2.1.0", 703 | "cross-spawn": "^6.0.5", 704 | "debug": "^4.0.1", 705 | "doctrine": "^3.0.0", 706 | "eslint-scope": "^5.0.0", 707 | "eslint-utils": "^1.4.3", 708 | "eslint-visitor-keys": "^1.1.0", 709 | "espree": "^6.1.2", 710 | "esquery": "^1.0.1", 711 | "esutils": "^2.0.2", 712 | "file-entry-cache": "^5.0.1", 713 | "functional-red-black-tree": "^1.0.1", 714 | "glob-parent": "^5.0.0", 715 | "globals": "^12.1.0", 716 | "ignore": "^4.0.6", 717 | "import-fresh": "^3.0.0", 718 | "imurmurhash": "^0.1.4", 719 | "inquirer": "^7.0.0", 720 | "is-glob": "^4.0.0", 721 | "js-yaml": "^3.13.1", 722 | "json-stable-stringify-without-jsonify": "^1.0.1", 723 | "levn": "^0.3.0", 724 | "lodash": "^4.17.14", 725 | "minimatch": "^3.0.4", 726 | "mkdirp": "^0.5.1", 727 | "natural-compare": "^1.4.0", 728 | "optionator": "^0.8.3", 729 | "progress": "^2.0.0", 730 | "regexpp": "^2.0.1", 731 | "semver": "^6.1.2", 732 | "strip-ansi": "^5.2.0", 733 | "strip-json-comments": "^3.0.1", 734 | "table": "^5.2.3", 735 | "text-table": "^0.2.0", 736 | "v8-compile-cache": "^2.0.3" 737 | }, 738 | "bin": { 739 | "eslint": "bin/eslint.js" 740 | }, 741 | "engines": { 742 | "node": "^8.10.0 || ^10.13.0 || >=11.10.1" 743 | }, 744 | "funding": { 745 | "url": "https://opencollective.com/eslint" 746 | } 747 | }, 748 | "node_modules/eslint-scope": { 749 | "version": "5.0.0", 750 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 751 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 752 | "dev": true, 753 | "dependencies": { 754 | "esrecurse": "^4.1.0", 755 | "estraverse": "^4.1.1" 756 | }, 757 | "engines": { 758 | "node": ">=8.0.0" 759 | } 760 | }, 761 | "node_modules/eslint-utils": { 762 | "version": "1.4.3", 763 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 764 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 765 | "dev": true, 766 | "dependencies": { 767 | "eslint-visitor-keys": "^1.1.0" 768 | }, 769 | "engines": { 770 | "node": ">=6" 771 | } 772 | }, 773 | "node_modules/eslint-visitor-keys": { 774 | "version": "1.1.0", 775 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 776 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 777 | "dev": true, 778 | "engines": { 779 | "node": ">=4" 780 | } 781 | }, 782 | "node_modules/eslint/node_modules/chalk": { 783 | "version": "2.4.2", 784 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 785 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 786 | "dev": true, 787 | "dependencies": { 788 | "ansi-styles": "^3.2.1", 789 | "escape-string-regexp": "^1.0.5", 790 | "supports-color": "^5.3.0" 791 | }, 792 | "engines": { 793 | "node": ">=4" 794 | } 795 | }, 796 | "node_modules/espree": { 797 | "version": "6.1.2", 798 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.1.2.tgz", 799 | "integrity": "sha512-2iUPuuPP+yW1PZaMSDM9eyVf8D5P0Hi8h83YtZ5bPc/zHYjII5khoixIUTMO794NOY8F/ThF1Bo8ncZILarUTA==", 800 | "dev": true, 801 | "dependencies": { 802 | "acorn": "^7.1.0", 803 | "acorn-jsx": "^5.1.0", 804 | "eslint-visitor-keys": "^1.1.0" 805 | }, 806 | "engines": { 807 | "node": ">=6.0.0" 808 | } 809 | }, 810 | "node_modules/esprima": { 811 | "version": "4.0.1", 812 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 813 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 814 | "dev": true, 815 | "bin": { 816 | "esparse": "bin/esparse.js", 817 | "esvalidate": "bin/esvalidate.js" 818 | }, 819 | "engines": { 820 | "node": ">=4" 821 | } 822 | }, 823 | "node_modules/esquery": { 824 | "version": "1.0.1", 825 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 826 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 827 | "dev": true, 828 | "dependencies": { 829 | "estraverse": "^4.0.0" 830 | }, 831 | "engines": { 832 | "node": ">=0.6" 833 | } 834 | }, 835 | "node_modules/esrecurse": { 836 | "version": "4.2.1", 837 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 838 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 839 | "dev": true, 840 | "dependencies": { 841 | "estraverse": "^4.1.0" 842 | }, 843 | "engines": { 844 | "node": ">=4.0" 845 | } 846 | }, 847 | "node_modules/estraverse": { 848 | "version": "4.3.0", 849 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 850 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 851 | "dev": true, 852 | "engines": { 853 | "node": ">=4.0" 854 | } 855 | }, 856 | "node_modules/esutils": { 857 | "version": "2.0.3", 858 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 859 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 860 | "dev": true, 861 | "engines": { 862 | "node": ">=0.10.0" 863 | } 864 | }, 865 | "node_modules/etag": { 866 | "version": "1.8.1", 867 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 868 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 869 | "engines": { 870 | "node": ">= 0.6" 871 | } 872 | }, 873 | "node_modules/express": { 874 | "version": "4.18.2", 875 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 876 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 877 | "dependencies": { 878 | "accepts": "~1.3.8", 879 | "array-flatten": "1.1.1", 880 | "body-parser": "1.20.1", 881 | "content-disposition": "0.5.4", 882 | "content-type": "~1.0.4", 883 | "cookie": "0.5.0", 884 | "cookie-signature": "1.0.6", 885 | "debug": "2.6.9", 886 | "depd": "2.0.0", 887 | "encodeurl": "~1.0.2", 888 | "escape-html": "~1.0.3", 889 | "etag": "~1.8.1", 890 | "finalhandler": "1.2.0", 891 | "fresh": "0.5.2", 892 | "http-errors": "2.0.0", 893 | "merge-descriptors": "1.0.1", 894 | "methods": "~1.1.2", 895 | "on-finished": "2.4.1", 896 | "parseurl": "~1.3.3", 897 | "path-to-regexp": "0.1.7", 898 | "proxy-addr": "~2.0.7", 899 | "qs": "6.11.0", 900 | "range-parser": "~1.2.1", 901 | "safe-buffer": "5.2.1", 902 | "send": "0.18.0", 903 | "serve-static": "1.15.0", 904 | "setprototypeof": "1.2.0", 905 | "statuses": "2.0.1", 906 | "type-is": "~1.6.18", 907 | "utils-merge": "1.0.1", 908 | "vary": "~1.1.2" 909 | }, 910 | "engines": { 911 | "node": ">= 0.10.0" 912 | } 913 | }, 914 | "node_modules/express-ga-middleware": { 915 | "version": "0.1.6", 916 | "resolved": "https://registry.npmjs.org/express-ga-middleware/-/express-ga-middleware-0.1.6.tgz", 917 | "integrity": "sha512-MrNs6PlAH6P0UYO96U641F0RC6Q67uwjwX3r6k7qwR9vqJy1jhnSMEb/N4vpLsf9UsvTMO8aiI7X7u3bITaBgQ==", 918 | "dependencies": { 919 | "universal-analytics": "^0.4.15" 920 | } 921 | }, 922 | "node_modules/express/node_modules/debug": { 923 | "version": "2.6.9", 924 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 925 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 926 | "dependencies": { 927 | "ms": "2.0.0" 928 | } 929 | }, 930 | "node_modules/express/node_modules/ms": { 931 | "version": "2.0.0", 932 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 933 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 934 | }, 935 | "node_modules/extend": { 936 | "version": "3.0.2", 937 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 938 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 939 | }, 940 | "node_modules/external-editor": { 941 | "version": "3.1.0", 942 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 943 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 944 | "dev": true, 945 | "dependencies": { 946 | "chardet": "^0.7.0", 947 | "iconv-lite": "^0.4.24", 948 | "tmp": "^0.0.33" 949 | }, 950 | "engines": { 951 | "node": ">=4" 952 | } 953 | }, 954 | "node_modules/extsprintf": { 955 | "version": "1.3.0", 956 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 957 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 958 | "engines": [ 959 | "node >=0.6.0" 960 | ] 961 | }, 962 | "node_modules/fast-deep-equal": { 963 | "version": "3.1.3", 964 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 965 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" 966 | }, 967 | "node_modules/fast-json-stable-stringify": { 968 | "version": "2.0.0", 969 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 970 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 971 | }, 972 | "node_modules/fast-levenshtein": { 973 | "version": "2.0.6", 974 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 975 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 976 | "dev": true 977 | }, 978 | "node_modules/fast-safe-stringify": { 979 | "version": "2.0.7", 980 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.7.tgz", 981 | "integrity": "sha512-Utm6CdzT+6xsDk2m8S6uL8VHxNwI6Jub+e9NYTcAms28T84pTa25GJQV9j0CY0N1rM8hK4x6grpF2BQf+2qwVA==", 982 | "dev": true 983 | }, 984 | "node_modules/figures": { 985 | "version": "3.1.0", 986 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.1.0.tgz", 987 | "integrity": "sha512-ravh8VRXqHuMvZt/d8GblBeqDMkdJMBdv/2KntFH+ra5MXkO7nxNKpzQ3n6QD/2da1kH0aWmNISdvhM7gl2gVg==", 988 | "dev": true, 989 | "dependencies": { 990 | "escape-string-regexp": "^1.0.5" 991 | }, 992 | "engines": { 993 | "node": ">=8" 994 | } 995 | }, 996 | "node_modules/file-entry-cache": { 997 | "version": "5.0.1", 998 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 999 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 1000 | "dev": true, 1001 | "dependencies": { 1002 | "flat-cache": "^2.0.1" 1003 | }, 1004 | "engines": { 1005 | "node": ">=4" 1006 | } 1007 | }, 1008 | "node_modules/fill-range": { 1009 | "version": "7.0.1", 1010 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1011 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1012 | "dev": true, 1013 | "dependencies": { 1014 | "to-regex-range": "^5.0.1" 1015 | }, 1016 | "engines": { 1017 | "node": ">=8" 1018 | } 1019 | }, 1020 | "node_modules/finalhandler": { 1021 | "version": "1.2.0", 1022 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 1023 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 1024 | "dependencies": { 1025 | "debug": "2.6.9", 1026 | "encodeurl": "~1.0.2", 1027 | "escape-html": "~1.0.3", 1028 | "on-finished": "2.4.1", 1029 | "parseurl": "~1.3.3", 1030 | "statuses": "2.0.1", 1031 | "unpipe": "~1.0.0" 1032 | }, 1033 | "engines": { 1034 | "node": ">= 0.8" 1035 | } 1036 | }, 1037 | "node_modules/finalhandler/node_modules/debug": { 1038 | "version": "2.6.9", 1039 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1040 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1041 | "dependencies": { 1042 | "ms": "2.0.0" 1043 | } 1044 | }, 1045 | "node_modules/finalhandler/node_modules/ms": { 1046 | "version": "2.0.0", 1047 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1048 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1049 | }, 1050 | "node_modules/flat-cache": { 1051 | "version": "2.0.1", 1052 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 1053 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 1054 | "dev": true, 1055 | "dependencies": { 1056 | "flatted": "^2.0.0", 1057 | "rimraf": "2.6.3", 1058 | "write": "1.0.3" 1059 | }, 1060 | "engines": { 1061 | "node": ">=4" 1062 | } 1063 | }, 1064 | "node_modules/flatted": { 1065 | "version": "2.0.1", 1066 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", 1067 | "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", 1068 | "dev": true 1069 | }, 1070 | "node_modules/forever-agent": { 1071 | "version": "0.6.1", 1072 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 1073 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 1074 | "engines": { 1075 | "node": "*" 1076 | } 1077 | }, 1078 | "node_modules/form-data": { 1079 | "version": "2.5.1", 1080 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.5.1.tgz", 1081 | "integrity": "sha512-m21N3WOmEEURgk6B9GLOE4RuWOFf28Lhh9qGYeNlGq4VDXUlJy2th2slBNU8Gp8EzloYZOibZJ7t5ecIrFSjVA==", 1082 | "dev": true, 1083 | "dependencies": { 1084 | "asynckit": "^0.4.0", 1085 | "combined-stream": "^1.0.6", 1086 | "mime-types": "^2.1.12" 1087 | }, 1088 | "engines": { 1089 | "node": ">= 0.12" 1090 | } 1091 | }, 1092 | "node_modules/formidable": { 1093 | "version": "1.2.1", 1094 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.2.1.tgz", 1095 | "integrity": "sha512-Fs9VRguL0gqGHkXS5GQiMCr1VhZBxz0JnJs4JmMp/2jL18Fmbzvv7vOFRU+U8TBkHEE/CX1qDXzJplVULgsLeg==", 1096 | "deprecated": "Please upgrade to latest, formidable@v2 or formidable@v3! Check these notes: https://bit.ly/2ZEqIau", 1097 | "dev": true 1098 | }, 1099 | "node_modules/forwarded": { 1100 | "version": "0.2.0", 1101 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 1102 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 1103 | "engines": { 1104 | "node": ">= 0.6" 1105 | } 1106 | }, 1107 | "node_modules/fresh": { 1108 | "version": "0.5.2", 1109 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1110 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 1111 | "engines": { 1112 | "node": ">= 0.6" 1113 | } 1114 | }, 1115 | "node_modules/fs.realpath": { 1116 | "version": "1.0.0", 1117 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1118 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1119 | "dev": true 1120 | }, 1121 | "node_modules/fsevents": { 1122 | "version": "2.3.2", 1123 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1124 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1125 | "dev": true, 1126 | "hasInstallScript": true, 1127 | "optional": true, 1128 | "os": [ 1129 | "darwin" 1130 | ], 1131 | "engines": { 1132 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1133 | } 1134 | }, 1135 | "node_modules/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 | "node_modules/functional-red-black-tree": { 1141 | "version": "1.0.1", 1142 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1143 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1144 | "dev": true 1145 | }, 1146 | "node_modules/get-intrinsic": { 1147 | "version": "1.1.3", 1148 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz", 1149 | "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==", 1150 | "dependencies": { 1151 | "function-bind": "^1.1.1", 1152 | "has": "^1.0.3", 1153 | "has-symbols": "^1.0.3" 1154 | }, 1155 | "funding": { 1156 | "url": "https://github.com/sponsors/ljharb" 1157 | } 1158 | }, 1159 | "node_modules/getpass": { 1160 | "version": "0.1.7", 1161 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 1162 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 1163 | "dependencies": { 1164 | "assert-plus": "^1.0.0" 1165 | } 1166 | }, 1167 | "node_modules/glob": { 1168 | "version": "7.1.6", 1169 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1170 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1171 | "dev": true, 1172 | "dependencies": { 1173 | "fs.realpath": "^1.0.0", 1174 | "inflight": "^1.0.4", 1175 | "inherits": "2", 1176 | "minimatch": "^3.0.4", 1177 | "once": "^1.3.0", 1178 | "path-is-absolute": "^1.0.0" 1179 | }, 1180 | "engines": { 1181 | "node": "*" 1182 | }, 1183 | "funding": { 1184 | "url": "https://github.com/sponsors/isaacs" 1185 | } 1186 | }, 1187 | "node_modules/glob-parent": { 1188 | "version": "5.1.2", 1189 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1190 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1191 | "dev": true, 1192 | "dependencies": { 1193 | "is-glob": "^4.0.1" 1194 | }, 1195 | "engines": { 1196 | "node": ">= 6" 1197 | } 1198 | }, 1199 | "node_modules/globals": { 1200 | "version": "12.3.0", 1201 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.3.0.tgz", 1202 | "integrity": "sha512-wAfjdLgFsPZsklLJvOBUBmzYE8/CwhEqSBEMRXA3qxIiNtyqvjYurAtIfDh6chlEPUfmTY3MnZh5Hfh4q0UlIw==", 1203 | "dev": true, 1204 | "dependencies": { 1205 | "type-fest": "^0.8.1" 1206 | }, 1207 | "engines": { 1208 | "node": ">=8" 1209 | } 1210 | }, 1211 | "node_modules/har-schema": { 1212 | "version": "2.0.0", 1213 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 1214 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 1215 | "engines": { 1216 | "node": ">=4" 1217 | } 1218 | }, 1219 | "node_modules/har-validator": { 1220 | "version": "5.1.3", 1221 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 1222 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 1223 | "deprecated": "this library is no longer supported", 1224 | "dependencies": { 1225 | "ajv": "^6.5.5", 1226 | "har-schema": "^2.0.0" 1227 | }, 1228 | "engines": { 1229 | "node": ">=6" 1230 | } 1231 | }, 1232 | "node_modules/has": { 1233 | "version": "1.0.3", 1234 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1235 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1236 | "dependencies": { 1237 | "function-bind": "^1.1.1" 1238 | }, 1239 | "engines": { 1240 | "node": ">= 0.4.0" 1241 | } 1242 | }, 1243 | "node_modules/has-flag": { 1244 | "version": "3.0.0", 1245 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1246 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1247 | "dev": true, 1248 | "engines": { 1249 | "node": ">=4" 1250 | } 1251 | }, 1252 | "node_modules/has-symbols": { 1253 | "version": "1.0.3", 1254 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 1255 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 1256 | "engines": { 1257 | "node": ">= 0.4" 1258 | }, 1259 | "funding": { 1260 | "url": "https://github.com/sponsors/ljharb" 1261 | } 1262 | }, 1263 | "node_modules/he": { 1264 | "version": "1.1.1", 1265 | "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", 1266 | "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", 1267 | "dev": true, 1268 | "bin": { 1269 | "he": "bin/he" 1270 | } 1271 | }, 1272 | "node_modules/http-errors": { 1273 | "version": "2.0.0", 1274 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 1275 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 1276 | "dependencies": { 1277 | "depd": "2.0.0", 1278 | "inherits": "2.0.4", 1279 | "setprototypeof": "1.2.0", 1280 | "statuses": "2.0.1", 1281 | "toidentifier": "1.0.1" 1282 | }, 1283 | "engines": { 1284 | "node": ">= 0.8" 1285 | } 1286 | }, 1287 | "node_modules/http-signature": { 1288 | "version": "1.2.0", 1289 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 1290 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 1291 | "dependencies": { 1292 | "assert-plus": "^1.0.0", 1293 | "jsprim": "^1.2.2", 1294 | "sshpk": "^1.7.0" 1295 | }, 1296 | "engines": { 1297 | "node": ">=0.8", 1298 | "npm": ">=1.3.7" 1299 | } 1300 | }, 1301 | "node_modules/iconv-lite": { 1302 | "version": "0.4.24", 1303 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1304 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1305 | "dependencies": { 1306 | "safer-buffer": ">= 2.1.2 < 3" 1307 | }, 1308 | "engines": { 1309 | "node": ">=0.10.0" 1310 | } 1311 | }, 1312 | "node_modules/ignore": { 1313 | "version": "4.0.6", 1314 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1315 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1316 | "dev": true, 1317 | "engines": { 1318 | "node": ">= 4" 1319 | } 1320 | }, 1321 | "node_modules/ignore-by-default": { 1322 | "version": "1.0.1", 1323 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1324 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1325 | "dev": true 1326 | }, 1327 | "node_modules/import-fresh": { 1328 | "version": "3.2.1", 1329 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 1330 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 1331 | "dev": true, 1332 | "dependencies": { 1333 | "parent-module": "^1.0.0", 1334 | "resolve-from": "^4.0.0" 1335 | }, 1336 | "engines": { 1337 | "node": ">=6" 1338 | } 1339 | }, 1340 | "node_modules/imurmurhash": { 1341 | "version": "0.1.4", 1342 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1343 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1344 | "dev": true, 1345 | "engines": { 1346 | "node": ">=0.8.19" 1347 | } 1348 | }, 1349 | "node_modules/inflight": { 1350 | "version": "1.0.6", 1351 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1352 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1353 | "dev": true, 1354 | "dependencies": { 1355 | "once": "^1.3.0", 1356 | "wrappy": "1" 1357 | } 1358 | }, 1359 | "node_modules/inherits": { 1360 | "version": "2.0.4", 1361 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1362 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1363 | }, 1364 | "node_modules/inquirer": { 1365 | "version": "7.0.0", 1366 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.0.0.tgz", 1367 | "integrity": "sha512-rSdC7zelHdRQFkWnhsMu2+2SO41mpv2oF2zy4tMhmiLWkcKbOAs87fWAJhVXttKVwhdZvymvnuM95EyEXg2/tQ==", 1368 | "dev": true, 1369 | "dependencies": { 1370 | "ansi-escapes": "^4.2.1", 1371 | "chalk": "^2.4.2", 1372 | "cli-cursor": "^3.1.0", 1373 | "cli-width": "^2.0.0", 1374 | "external-editor": "^3.0.3", 1375 | "figures": "^3.0.0", 1376 | "lodash": "^4.17.15", 1377 | "mute-stream": "0.0.8", 1378 | "run-async": "^2.2.0", 1379 | "rxjs": "^6.4.0", 1380 | "string-width": "^4.1.0", 1381 | "strip-ansi": "^5.1.0", 1382 | "through": "^2.3.6" 1383 | }, 1384 | "engines": { 1385 | "node": ">=6.0.0" 1386 | } 1387 | }, 1388 | "node_modules/inquirer/node_modules/chalk": { 1389 | "version": "2.4.2", 1390 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1391 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1392 | "dev": true, 1393 | "dependencies": { 1394 | "ansi-styles": "^3.2.1", 1395 | "escape-string-regexp": "^1.0.5", 1396 | "supports-color": "^5.3.0" 1397 | }, 1398 | "engines": { 1399 | "node": ">=4" 1400 | } 1401 | }, 1402 | "node_modules/ipaddr.js": { 1403 | "version": "1.9.1", 1404 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1405 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 1406 | "engines": { 1407 | "node": ">= 0.10" 1408 | } 1409 | }, 1410 | "node_modules/is-binary-path": { 1411 | "version": "2.1.0", 1412 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1413 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1414 | "dev": true, 1415 | "dependencies": { 1416 | "binary-extensions": "^2.0.0" 1417 | }, 1418 | "engines": { 1419 | "node": ">=8" 1420 | } 1421 | }, 1422 | "node_modules/is-extglob": { 1423 | "version": "2.1.1", 1424 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1425 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1426 | "dev": true, 1427 | "engines": { 1428 | "node": ">=0.10.0" 1429 | } 1430 | }, 1431 | "node_modules/is-fullwidth-code-point": { 1432 | "version": "3.0.0", 1433 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1434 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1435 | "dev": true, 1436 | "engines": { 1437 | "node": ">=8" 1438 | } 1439 | }, 1440 | "node_modules/is-glob": { 1441 | "version": "4.0.1", 1442 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1443 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1444 | "dev": true, 1445 | "dependencies": { 1446 | "is-extglob": "^2.1.1" 1447 | }, 1448 | "engines": { 1449 | "node": ">=0.10.0" 1450 | } 1451 | }, 1452 | "node_modules/is-number": { 1453 | "version": "7.0.0", 1454 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1455 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1456 | "dev": true, 1457 | "engines": { 1458 | "node": ">=0.12.0" 1459 | } 1460 | }, 1461 | "node_modules/is-promise": { 1462 | "version": "2.1.0", 1463 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1464 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1465 | "dev": true 1466 | }, 1467 | "node_modules/is-typedarray": { 1468 | "version": "1.0.0", 1469 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1470 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 1471 | }, 1472 | "node_modules/isarray": { 1473 | "version": "1.0.0", 1474 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1475 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" 1476 | }, 1477 | "node_modules/isexe": { 1478 | "version": "2.0.0", 1479 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1480 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1481 | "dev": true 1482 | }, 1483 | "node_modules/isstream": { 1484 | "version": "0.1.2", 1485 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1486 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 1487 | }, 1488 | "node_modules/js-tokens": { 1489 | "version": "4.0.0", 1490 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1491 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1492 | "dev": true 1493 | }, 1494 | "node_modules/js-yaml": { 1495 | "version": "3.13.1", 1496 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1497 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1498 | "dev": true, 1499 | "dependencies": { 1500 | "argparse": "^1.0.7", 1501 | "esprima": "^4.0.0" 1502 | }, 1503 | "bin": { 1504 | "js-yaml": "bin/js-yaml.js" 1505 | } 1506 | }, 1507 | "node_modules/jsbn": { 1508 | "version": "0.1.1", 1509 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1510 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" 1511 | }, 1512 | "node_modules/json-schema": { 1513 | "version": "0.4.0", 1514 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.4.0.tgz", 1515 | "integrity": "sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==" 1516 | }, 1517 | "node_modules/json-schema-traverse": { 1518 | "version": "0.4.1", 1519 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1520 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 1521 | }, 1522 | "node_modules/json-stable-stringify-without-jsonify": { 1523 | "version": "1.0.1", 1524 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1525 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1526 | "dev": true 1527 | }, 1528 | "node_modules/json-stringify-safe": { 1529 | "version": "5.0.1", 1530 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1531 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 1532 | }, 1533 | "node_modules/jsprim": { 1534 | "version": "1.4.2", 1535 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.2.tgz", 1536 | "integrity": "sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw==", 1537 | "dependencies": { 1538 | "assert-plus": "1.0.0", 1539 | "extsprintf": "1.3.0", 1540 | "json-schema": "0.4.0", 1541 | "verror": "1.10.0" 1542 | }, 1543 | "engines": { 1544 | "node": ">=0.6.0" 1545 | } 1546 | }, 1547 | "node_modules/kareem": { 1548 | "version": "2.3.2", 1549 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.2.tgz", 1550 | "integrity": "sha512-STHz9P7X2L4Kwn72fA4rGyqyXdmrMSdxqHx9IXon/FXluXieaFA6KJ2upcHAHxQPQ0LeM/OjLrhFxifHewOALQ==" 1551 | }, 1552 | "node_modules/levn": { 1553 | "version": "0.3.0", 1554 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1555 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1556 | "dev": true, 1557 | "dependencies": { 1558 | "prelude-ls": "~1.1.2", 1559 | "type-check": "~0.3.2" 1560 | }, 1561 | "engines": { 1562 | "node": ">= 0.8.0" 1563 | } 1564 | }, 1565 | "node_modules/lodash": { 1566 | "version": "4.17.21", 1567 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1568 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1569 | "dev": true 1570 | }, 1571 | "node_modules/media-typer": { 1572 | "version": "0.3.0", 1573 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1574 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1575 | "engines": { 1576 | "node": ">= 0.6" 1577 | } 1578 | }, 1579 | "node_modules/memory-pager": { 1580 | "version": "1.5.0", 1581 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1582 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1583 | "optional": true 1584 | }, 1585 | "node_modules/merge-descriptors": { 1586 | "version": "1.0.1", 1587 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1588 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1589 | }, 1590 | "node_modules/methods": { 1591 | "version": "1.1.2", 1592 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1593 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1594 | "engines": { 1595 | "node": ">= 0.6" 1596 | } 1597 | }, 1598 | "node_modules/mime": { 1599 | "version": "2.4.4", 1600 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.4.4.tgz", 1601 | "integrity": "sha512-LRxmNwziLPT828z+4YkNzloCFC2YM4wrB99k+AV5ZbEyfGNWfG8SO1FUXLmLDBSo89NrJZ4DIWeLjy1CHGhMGA==", 1602 | "dev": true, 1603 | "bin": { 1604 | "mime": "cli.js" 1605 | }, 1606 | "engines": { 1607 | "node": ">=4.0.0" 1608 | } 1609 | }, 1610 | "node_modules/mime-db": { 1611 | "version": "1.52.0", 1612 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1613 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1614 | "engines": { 1615 | "node": ">= 0.6" 1616 | } 1617 | }, 1618 | "node_modules/mime-types": { 1619 | "version": "2.1.35", 1620 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1621 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1622 | "dependencies": { 1623 | "mime-db": "1.52.0" 1624 | }, 1625 | "engines": { 1626 | "node": ">= 0.6" 1627 | } 1628 | }, 1629 | "node_modules/mimic-fn": { 1630 | "version": "2.1.0", 1631 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1632 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1633 | "dev": true, 1634 | "engines": { 1635 | "node": ">=6" 1636 | } 1637 | }, 1638 | "node_modules/minimatch": { 1639 | "version": "3.1.2", 1640 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1641 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1642 | "dev": true, 1643 | "dependencies": { 1644 | "brace-expansion": "^1.1.7" 1645 | }, 1646 | "engines": { 1647 | "node": "*" 1648 | } 1649 | }, 1650 | "node_modules/minimist": { 1651 | "version": "1.2.7", 1652 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz", 1653 | "integrity": "sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g==", 1654 | "dev": true, 1655 | "funding": { 1656 | "url": "https://github.com/sponsors/ljharb" 1657 | } 1658 | }, 1659 | "node_modules/mkdirp": { 1660 | "version": "0.5.3", 1661 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.3.tgz", 1662 | "integrity": "sha512-P+2gwrFqx8lhew375MQHHeTlY8AuOJSrGf0R5ddkEndUkmwpgUob/vQuBD1V22/Cw1/lJr4x+EjllSezBThzBg==", 1663 | "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)", 1664 | "dev": true, 1665 | "dependencies": { 1666 | "minimist": "^1.2.5" 1667 | }, 1668 | "bin": { 1669 | "mkdirp": "bin/cmd.js" 1670 | } 1671 | }, 1672 | "node_modules/mongodb": { 1673 | "version": "3.7.3", 1674 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.7.3.tgz", 1675 | "integrity": "sha512-Psm+g3/wHXhjBEktkxXsFMZvd3nemI0r3IPsE0bU+4//PnvNWKkzhZcEsbPcYiWqe8XqXJJEg4Tgtr7Raw67Yw==", 1676 | "dependencies": { 1677 | "bl": "^2.2.1", 1678 | "bson": "^1.1.4", 1679 | "denque": "^1.4.1", 1680 | "optional-require": "^1.1.8", 1681 | "safe-buffer": "^5.1.2" 1682 | }, 1683 | "engines": { 1684 | "node": ">=4" 1685 | }, 1686 | "optionalDependencies": { 1687 | "saslprep": "^1.0.0" 1688 | }, 1689 | "peerDependenciesMeta": { 1690 | "aws4": { 1691 | "optional": true 1692 | }, 1693 | "bson-ext": { 1694 | "optional": true 1695 | }, 1696 | "kerberos": { 1697 | "optional": true 1698 | }, 1699 | "mongodb-client-encryption": { 1700 | "optional": true 1701 | }, 1702 | "mongodb-extjson": { 1703 | "optional": true 1704 | }, 1705 | "snappy": { 1706 | "optional": true 1707 | } 1708 | } 1709 | }, 1710 | "node_modules/mongodb/node_modules/optional-require": { 1711 | "version": "1.1.8", 1712 | "resolved": "https://registry.npmjs.org/optional-require/-/optional-require-1.1.8.tgz", 1713 | "integrity": "sha512-jq83qaUb0wNg9Krv1c5OQ+58EK+vHde6aBPzLvPPqJm89UQWsvSuFy9X/OSNJnFeSOKo7btE0n8Nl2+nE+z5nA==", 1714 | "dependencies": { 1715 | "require-at": "^1.0.6" 1716 | }, 1717 | "engines": { 1718 | "node": ">=4" 1719 | } 1720 | }, 1721 | "node_modules/mongoose": { 1722 | "version": "5.13.15", 1723 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.13.15.tgz", 1724 | "integrity": "sha512-cxp1Gbb8yUWkaEbajdhspSaKzAvsIvOtRlYD87GN/P2QEUhpd6bIvebi36T6M0tIVAMauNaK9SPA055N3PwF8Q==", 1725 | "dependencies": { 1726 | "@types/bson": "1.x || 4.0.x", 1727 | "@types/mongodb": "^3.5.27", 1728 | "bson": "^1.1.4", 1729 | "kareem": "2.3.2", 1730 | "mongodb": "3.7.3", 1731 | "mongoose-legacy-pluralize": "1.0.2", 1732 | "mpath": "0.8.4", 1733 | "mquery": "3.2.5", 1734 | "ms": "2.1.2", 1735 | "optional-require": "1.0.x", 1736 | "regexp-clone": "1.0.0", 1737 | "safe-buffer": "5.2.1", 1738 | "sift": "13.5.2", 1739 | "sliced": "1.0.1" 1740 | }, 1741 | "engines": { 1742 | "node": ">=4.0.0" 1743 | }, 1744 | "funding": { 1745 | "type": "opencollective", 1746 | "url": "https://opencollective.com/mongoose" 1747 | } 1748 | }, 1749 | "node_modules/mongoose-legacy-pluralize": { 1750 | "version": "1.0.2", 1751 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 1752 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==", 1753 | "peerDependencies": { 1754 | "mongoose": "*" 1755 | } 1756 | }, 1757 | "node_modules/mpath": { 1758 | "version": "0.8.4", 1759 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.4.tgz", 1760 | "integrity": "sha512-DTxNZomBcTWlrMW76jy1wvV37X/cNNxPW1y2Jzd4DZkAaC5ZGsm8bfGfNOthcDuRJujXLqiuS6o3Tpy0JEoh7g==", 1761 | "engines": { 1762 | "node": ">=4.0.0" 1763 | } 1764 | }, 1765 | "node_modules/mquery": { 1766 | "version": "3.2.5", 1767 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.5.tgz", 1768 | "integrity": "sha512-VjOKHHgU84wij7IUoZzFRU07IAxd5kWJaDmyUzQlbjHjyoeK5TNeeo8ZsFDtTYnSgpW6n/nMNIHvE3u8Lbrf4A==", 1769 | "dependencies": { 1770 | "bluebird": "3.5.1", 1771 | "debug": "3.1.0", 1772 | "regexp-clone": "^1.0.0", 1773 | "safe-buffer": "5.1.2", 1774 | "sliced": "1.0.1" 1775 | }, 1776 | "engines": { 1777 | "node": ">=4.0.0" 1778 | } 1779 | }, 1780 | "node_modules/mquery/node_modules/debug": { 1781 | "version": "3.1.0", 1782 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1783 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1784 | "dependencies": { 1785 | "ms": "2.0.0" 1786 | } 1787 | }, 1788 | "node_modules/mquery/node_modules/ms": { 1789 | "version": "2.0.0", 1790 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1791 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1792 | }, 1793 | "node_modules/mquery/node_modules/safe-buffer": { 1794 | "version": "5.1.2", 1795 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1796 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1797 | }, 1798 | "node_modules/ms": { 1799 | "version": "2.1.2", 1800 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1801 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1802 | }, 1803 | "node_modules/mute-stream": { 1804 | "version": "0.0.8", 1805 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1806 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1807 | "dev": true 1808 | }, 1809 | "node_modules/natural-compare": { 1810 | "version": "1.4.0", 1811 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1812 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1813 | "dev": true 1814 | }, 1815 | "node_modules/negotiator": { 1816 | "version": "0.6.3", 1817 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1818 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1819 | "engines": { 1820 | "node": ">= 0.6" 1821 | } 1822 | }, 1823 | "node_modules/nice-try": { 1824 | "version": "1.0.5", 1825 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1826 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1827 | "dev": true 1828 | }, 1829 | "node_modules/node-html-parser": { 1830 | "version": "1.1.16", 1831 | "resolved": "https://registry.npmjs.org/node-html-parser/-/node-html-parser-1.1.16.tgz", 1832 | "integrity": "sha512-cfqTZIYDdp5cGh3NvCD5dcEDP7hfyni7WgyFacmDynLlIZaF3GVlRk8yMARhWp/PobWt1KaCV8VKdP5LKWiVbg==", 1833 | "dev": true, 1834 | "dependencies": { 1835 | "he": "1.1.1" 1836 | } 1837 | }, 1838 | "node_modules/nodemon": { 1839 | "version": "2.0.20", 1840 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.20.tgz", 1841 | "integrity": "sha512-Km2mWHKKY5GzRg6i1j5OxOHQtuvVsgskLfigG25yTtbyfRGn/GNvIbRyOf1PSCKJ2aT/58TiuUsuOU5UToVViw==", 1842 | "dev": true, 1843 | "dependencies": { 1844 | "chokidar": "^3.5.2", 1845 | "debug": "^3.2.7", 1846 | "ignore-by-default": "^1.0.1", 1847 | "minimatch": "^3.1.2", 1848 | "pstree.remy": "^1.1.8", 1849 | "semver": "^5.7.1", 1850 | "simple-update-notifier": "^1.0.7", 1851 | "supports-color": "^5.5.0", 1852 | "touch": "^3.1.0", 1853 | "undefsafe": "^2.0.5" 1854 | }, 1855 | "bin": { 1856 | "nodemon": "bin/nodemon.js" 1857 | }, 1858 | "engines": { 1859 | "node": ">=8.10.0" 1860 | }, 1861 | "funding": { 1862 | "type": "opencollective", 1863 | "url": "https://opencollective.com/nodemon" 1864 | } 1865 | }, 1866 | "node_modules/nodemon/node_modules/debug": { 1867 | "version": "3.2.7", 1868 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1869 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1870 | "dev": true, 1871 | "dependencies": { 1872 | "ms": "^2.1.1" 1873 | } 1874 | }, 1875 | "node_modules/nodemon/node_modules/semver": { 1876 | "version": "5.7.1", 1877 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1878 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1879 | "dev": true, 1880 | "bin": { 1881 | "semver": "bin/semver" 1882 | } 1883 | }, 1884 | "node_modules/nopt": { 1885 | "version": "1.0.10", 1886 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1887 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1888 | "dev": true, 1889 | "dependencies": { 1890 | "abbrev": "1" 1891 | }, 1892 | "bin": { 1893 | "nopt": "bin/nopt.js" 1894 | }, 1895 | "engines": { 1896 | "node": "*" 1897 | } 1898 | }, 1899 | "node_modules/normalize-path": { 1900 | "version": "3.0.0", 1901 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1902 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1903 | "dev": true, 1904 | "engines": { 1905 | "node": ">=0.10.0" 1906 | } 1907 | }, 1908 | "node_modules/oauth-sign": { 1909 | "version": "0.9.0", 1910 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 1911 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 1912 | "engines": { 1913 | "node": "*" 1914 | } 1915 | }, 1916 | "node_modules/object-assign": { 1917 | "version": "4.1.1", 1918 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1919 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1920 | "engines": { 1921 | "node": ">=0.10.0" 1922 | } 1923 | }, 1924 | "node_modules/object-inspect": { 1925 | "version": "1.12.3", 1926 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 1927 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 1928 | "funding": { 1929 | "url": "https://github.com/sponsors/ljharb" 1930 | } 1931 | }, 1932 | "node_modules/on-finished": { 1933 | "version": "2.4.1", 1934 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1935 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1936 | "dependencies": { 1937 | "ee-first": "1.1.1" 1938 | }, 1939 | "engines": { 1940 | "node": ">= 0.8" 1941 | } 1942 | }, 1943 | "node_modules/once": { 1944 | "version": "1.4.0", 1945 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1946 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1947 | "dev": true, 1948 | "dependencies": { 1949 | "wrappy": "1" 1950 | } 1951 | }, 1952 | "node_modules/onetime": { 1953 | "version": "5.1.0", 1954 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1955 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1956 | "dev": true, 1957 | "dependencies": { 1958 | "mimic-fn": "^2.1.0" 1959 | }, 1960 | "engines": { 1961 | "node": ">=6" 1962 | } 1963 | }, 1964 | "node_modules/optional-require": { 1965 | "version": "1.0.3", 1966 | "resolved": "https://registry.npmjs.org/optional-require/-/optional-require-1.0.3.tgz", 1967 | "integrity": "sha512-RV2Zp2MY2aeYK5G+B/Sps8lW5NHAzE5QClbFP15j+PWmP+T9PxlJXBOOLoSAdgwFvS4t0aMR4vpedMkbHfh0nA==", 1968 | "engines": { 1969 | "node": ">=4" 1970 | } 1971 | }, 1972 | "node_modules/optionator": { 1973 | "version": "0.8.3", 1974 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 1975 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 1976 | "dev": true, 1977 | "dependencies": { 1978 | "deep-is": "~0.1.3", 1979 | "fast-levenshtein": "~2.0.6", 1980 | "levn": "~0.3.0", 1981 | "prelude-ls": "~1.1.2", 1982 | "type-check": "~0.3.2", 1983 | "word-wrap": "~1.2.3" 1984 | }, 1985 | "engines": { 1986 | "node": ">= 0.8.0" 1987 | } 1988 | }, 1989 | "node_modules/os-tmpdir": { 1990 | "version": "1.0.2", 1991 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1992 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1993 | "dev": true, 1994 | "engines": { 1995 | "node": ">=0.10.0" 1996 | } 1997 | }, 1998 | "node_modules/parent-module": { 1999 | "version": "1.0.1", 2000 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2001 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2002 | "dev": true, 2003 | "dependencies": { 2004 | "callsites": "^3.0.0" 2005 | }, 2006 | "engines": { 2007 | "node": ">=6" 2008 | } 2009 | }, 2010 | "node_modules/parseurl": { 2011 | "version": "1.3.3", 2012 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2013 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 2014 | "engines": { 2015 | "node": ">= 0.8" 2016 | } 2017 | }, 2018 | "node_modules/path-is-absolute": { 2019 | "version": "1.0.1", 2020 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2021 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2022 | "dev": true, 2023 | "engines": { 2024 | "node": ">=0.10.0" 2025 | } 2026 | }, 2027 | "node_modules/path-key": { 2028 | "version": "2.0.1", 2029 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2030 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2031 | "dev": true, 2032 | "engines": { 2033 | "node": ">=4" 2034 | } 2035 | }, 2036 | "node_modules/path-to-regexp": { 2037 | "version": "0.1.7", 2038 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2039 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2040 | }, 2041 | "node_modules/performance-now": { 2042 | "version": "2.1.0", 2043 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 2044 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 2045 | }, 2046 | "node_modules/picomatch": { 2047 | "version": "2.3.1", 2048 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2049 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2050 | "dev": true, 2051 | "engines": { 2052 | "node": ">=8.6" 2053 | }, 2054 | "funding": { 2055 | "url": "https://github.com/sponsors/jonschlinkert" 2056 | } 2057 | }, 2058 | "node_modules/prelude-ls": { 2059 | "version": "1.1.2", 2060 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2061 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2062 | "dev": true, 2063 | "engines": { 2064 | "node": ">= 0.8.0" 2065 | } 2066 | }, 2067 | "node_modules/process-nextick-args": { 2068 | "version": "2.0.1", 2069 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2070 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 2071 | }, 2072 | "node_modules/progress": { 2073 | "version": "2.0.3", 2074 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2075 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2076 | "dev": true, 2077 | "engines": { 2078 | "node": ">=0.4.0" 2079 | } 2080 | }, 2081 | "node_modules/proxy-addr": { 2082 | "version": "2.0.7", 2083 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2084 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2085 | "dependencies": { 2086 | "forwarded": "0.2.0", 2087 | "ipaddr.js": "1.9.1" 2088 | }, 2089 | "engines": { 2090 | "node": ">= 0.10" 2091 | } 2092 | }, 2093 | "node_modules/psl": { 2094 | "version": "1.7.0", 2095 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.7.0.tgz", 2096 | "integrity": "sha512-5NsSEDv8zY70ScRnOTn7bK7eanl2MvFrOrS/R6x+dBt5g1ghnj9Zv90kO8GwT8gxcu2ANyFprnFYB85IogIJOQ==" 2097 | }, 2098 | "node_modules/pstree.remy": { 2099 | "version": "1.1.8", 2100 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 2101 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 2102 | "dev": true 2103 | }, 2104 | "node_modules/punycode": { 2105 | "version": "2.1.1", 2106 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2107 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2108 | "engines": { 2109 | "node": ">=6" 2110 | } 2111 | }, 2112 | "node_modules/qs": { 2113 | "version": "6.11.0", 2114 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 2115 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 2116 | "dependencies": { 2117 | "side-channel": "^1.0.4" 2118 | }, 2119 | "engines": { 2120 | "node": ">=0.6" 2121 | }, 2122 | "funding": { 2123 | "url": "https://github.com/sponsors/ljharb" 2124 | } 2125 | }, 2126 | "node_modules/querystring": { 2127 | "version": "0.2.0", 2128 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 2129 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", 2130 | "deprecated": "The querystring API is considered Legacy. new code should use the URLSearchParams API instead.", 2131 | "engines": { 2132 | "node": ">=0.4.x" 2133 | } 2134 | }, 2135 | "node_modules/range-parser": { 2136 | "version": "1.2.1", 2137 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2138 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 2139 | "engines": { 2140 | "node": ">= 0.6" 2141 | } 2142 | }, 2143 | "node_modules/raw-body": { 2144 | "version": "2.5.1", 2145 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 2146 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 2147 | "dependencies": { 2148 | "bytes": "3.1.2", 2149 | "http-errors": "2.0.0", 2150 | "iconv-lite": "0.4.24", 2151 | "unpipe": "1.0.0" 2152 | }, 2153 | "engines": { 2154 | "node": ">= 0.8" 2155 | } 2156 | }, 2157 | "node_modules/readable-stream": { 2158 | "version": "3.4.0", 2159 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.4.0.tgz", 2160 | "integrity": "sha512-jItXPLmrSR8jmTRmRWJXCnGJsfy85mB3Wd/uINMXA65yrnFo0cPClFIUWzo2najVNSl+mx7/4W8ttlLWJe99pQ==", 2161 | "dev": true, 2162 | "dependencies": { 2163 | "inherits": "^2.0.3", 2164 | "string_decoder": "^1.1.1", 2165 | "util-deprecate": "^1.0.1" 2166 | }, 2167 | "engines": { 2168 | "node": ">= 6" 2169 | } 2170 | }, 2171 | "node_modules/readdirp": { 2172 | "version": "3.6.0", 2173 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2174 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2175 | "dev": true, 2176 | "dependencies": { 2177 | "picomatch": "^2.2.1" 2178 | }, 2179 | "engines": { 2180 | "node": ">=8.10.0" 2181 | } 2182 | }, 2183 | "node_modules/regexp-clone": { 2184 | "version": "1.0.0", 2185 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 2186 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 2187 | }, 2188 | "node_modules/regexpp": { 2189 | "version": "2.0.1", 2190 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 2191 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 2192 | "dev": true, 2193 | "engines": { 2194 | "node": ">=6.5.0" 2195 | } 2196 | }, 2197 | "node_modules/request": { 2198 | "version": "2.88.2", 2199 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 2200 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 2201 | "deprecated": "request has been deprecated, see https://github.com/request/request/issues/3142", 2202 | "dependencies": { 2203 | "aws-sign2": "~0.7.0", 2204 | "aws4": "^1.8.0", 2205 | "caseless": "~0.12.0", 2206 | "combined-stream": "~1.0.6", 2207 | "extend": "~3.0.2", 2208 | "forever-agent": "~0.6.1", 2209 | "form-data": "~2.3.2", 2210 | "har-validator": "~5.1.3", 2211 | "http-signature": "~1.2.0", 2212 | "is-typedarray": "~1.0.0", 2213 | "isstream": "~0.1.2", 2214 | "json-stringify-safe": "~5.0.1", 2215 | "mime-types": "~2.1.19", 2216 | "oauth-sign": "~0.9.0", 2217 | "performance-now": "^2.1.0", 2218 | "qs": "~6.5.2", 2219 | "safe-buffer": "^5.1.2", 2220 | "tough-cookie": "~2.5.0", 2221 | "tunnel-agent": "^0.6.0", 2222 | "uuid": "^3.3.2" 2223 | }, 2224 | "engines": { 2225 | "node": ">= 6" 2226 | } 2227 | }, 2228 | "node_modules/request/node_modules/form-data": { 2229 | "version": "2.3.3", 2230 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 2231 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 2232 | "dependencies": { 2233 | "asynckit": "^0.4.0", 2234 | "combined-stream": "^1.0.6", 2235 | "mime-types": "^2.1.12" 2236 | }, 2237 | "engines": { 2238 | "node": ">= 0.12" 2239 | } 2240 | }, 2241 | "node_modules/request/node_modules/qs": { 2242 | "version": "6.5.3", 2243 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.3.tgz", 2244 | "integrity": "sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA==", 2245 | "engines": { 2246 | "node": ">=0.6" 2247 | } 2248 | }, 2249 | "node_modules/require-at": { 2250 | "version": "1.0.6", 2251 | "resolved": "https://registry.npmjs.org/require-at/-/require-at-1.0.6.tgz", 2252 | "integrity": "sha512-7i1auJbMUrXEAZCOQ0VNJgmcT2VOKPRl2YGJwgpHpC9CE91Mv4/4UYIUm4chGJaI381ZDq1JUicFii64Hapd8g==", 2253 | "engines": { 2254 | "node": ">=4" 2255 | } 2256 | }, 2257 | "node_modules/resolve-from": { 2258 | "version": "4.0.0", 2259 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2260 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2261 | "dev": true, 2262 | "engines": { 2263 | "node": ">=4" 2264 | } 2265 | }, 2266 | "node_modules/restore-cursor": { 2267 | "version": "3.1.0", 2268 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 2269 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 2270 | "dev": true, 2271 | "dependencies": { 2272 | "onetime": "^5.1.0", 2273 | "signal-exit": "^3.0.2" 2274 | }, 2275 | "engines": { 2276 | "node": ">=8" 2277 | } 2278 | }, 2279 | "node_modules/rimraf": { 2280 | "version": "2.6.3", 2281 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 2282 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 2283 | "dev": true, 2284 | "dependencies": { 2285 | "glob": "^7.1.3" 2286 | }, 2287 | "bin": { 2288 | "rimraf": "bin.js" 2289 | } 2290 | }, 2291 | "node_modules/run-async": { 2292 | "version": "2.3.0", 2293 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 2294 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 2295 | "dev": true, 2296 | "dependencies": { 2297 | "is-promise": "^2.1.0" 2298 | }, 2299 | "engines": { 2300 | "node": ">=0.12.0" 2301 | } 2302 | }, 2303 | "node_modules/rxjs": { 2304 | "version": "6.5.3", 2305 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.3.tgz", 2306 | "integrity": "sha512-wuYsAYYFdWTAnAaPoKGNhfpWwKZbJW+HgAJ+mImp+Epl7BG8oNWBCTyRM8gba9k4lk8BgWdoYm21Mo/RYhhbgA==", 2307 | "dev": true, 2308 | "dependencies": { 2309 | "tslib": "^1.9.0" 2310 | }, 2311 | "engines": { 2312 | "npm": ">=2.0.0" 2313 | } 2314 | }, 2315 | "node_modules/safe-buffer": { 2316 | "version": "5.2.1", 2317 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2318 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 2319 | "funding": [ 2320 | { 2321 | "type": "github", 2322 | "url": "https://github.com/sponsors/feross" 2323 | }, 2324 | { 2325 | "type": "patreon", 2326 | "url": "https://www.patreon.com/feross" 2327 | }, 2328 | { 2329 | "type": "consulting", 2330 | "url": "https://feross.org/support" 2331 | } 2332 | ] 2333 | }, 2334 | "node_modules/safer-buffer": { 2335 | "version": "2.1.2", 2336 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2337 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2338 | }, 2339 | "node_modules/saslprep": { 2340 | "version": "1.0.3", 2341 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 2342 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 2343 | "optional": true, 2344 | "dependencies": { 2345 | "sparse-bitfield": "^3.0.3" 2346 | }, 2347 | "engines": { 2348 | "node": ">=6" 2349 | } 2350 | }, 2351 | "node_modules/semver": { 2352 | "version": "6.3.0", 2353 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2354 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2355 | "dev": true, 2356 | "bin": { 2357 | "semver": "bin/semver.js" 2358 | } 2359 | }, 2360 | "node_modules/send": { 2361 | "version": "0.18.0", 2362 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 2363 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 2364 | "dependencies": { 2365 | "debug": "2.6.9", 2366 | "depd": "2.0.0", 2367 | "destroy": "1.2.0", 2368 | "encodeurl": "~1.0.2", 2369 | "escape-html": "~1.0.3", 2370 | "etag": "~1.8.1", 2371 | "fresh": "0.5.2", 2372 | "http-errors": "2.0.0", 2373 | "mime": "1.6.0", 2374 | "ms": "2.1.3", 2375 | "on-finished": "2.4.1", 2376 | "range-parser": "~1.2.1", 2377 | "statuses": "2.0.1" 2378 | }, 2379 | "engines": { 2380 | "node": ">= 0.8.0" 2381 | } 2382 | }, 2383 | "node_modules/send/node_modules/debug": { 2384 | "version": "2.6.9", 2385 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2386 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2387 | "dependencies": { 2388 | "ms": "2.0.0" 2389 | } 2390 | }, 2391 | "node_modules/send/node_modules/debug/node_modules/ms": { 2392 | "version": "2.0.0", 2393 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2394 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 2395 | }, 2396 | "node_modules/send/node_modules/mime": { 2397 | "version": "1.6.0", 2398 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2399 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 2400 | "bin": { 2401 | "mime": "cli.js" 2402 | }, 2403 | "engines": { 2404 | "node": ">=4" 2405 | } 2406 | }, 2407 | "node_modules/send/node_modules/ms": { 2408 | "version": "2.1.3", 2409 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2410 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2411 | }, 2412 | "node_modules/serve-static": { 2413 | "version": "1.15.0", 2414 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 2415 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 2416 | "dependencies": { 2417 | "encodeurl": "~1.0.2", 2418 | "escape-html": "~1.0.3", 2419 | "parseurl": "~1.3.3", 2420 | "send": "0.18.0" 2421 | }, 2422 | "engines": { 2423 | "node": ">= 0.8.0" 2424 | } 2425 | }, 2426 | "node_modules/setprototypeof": { 2427 | "version": "1.2.0", 2428 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 2429 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 2430 | }, 2431 | "node_modules/shebang-command": { 2432 | "version": "1.2.0", 2433 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2434 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2435 | "dev": true, 2436 | "dependencies": { 2437 | "shebang-regex": "^1.0.0" 2438 | }, 2439 | "engines": { 2440 | "node": ">=0.10.0" 2441 | } 2442 | }, 2443 | "node_modules/shebang-regex": { 2444 | "version": "1.0.0", 2445 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2446 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2447 | "dev": true, 2448 | "engines": { 2449 | "node": ">=0.10.0" 2450 | } 2451 | }, 2452 | "node_modules/side-channel": { 2453 | "version": "1.0.4", 2454 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2455 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2456 | "dependencies": { 2457 | "call-bind": "^1.0.0", 2458 | "get-intrinsic": "^1.0.2", 2459 | "object-inspect": "^1.9.0" 2460 | }, 2461 | "funding": { 2462 | "url": "https://github.com/sponsors/ljharb" 2463 | } 2464 | }, 2465 | "node_modules/sift": { 2466 | "version": "13.5.2", 2467 | "resolved": "https://registry.npmjs.org/sift/-/sift-13.5.2.tgz", 2468 | "integrity": "sha512-+gxdEOMA2J+AI+fVsCqeNn7Tgx3M9ZN9jdi95939l1IJ8cZsqS8sqpJyOkic2SJk+1+98Uwryt/gL6XDaV+UZA==" 2469 | }, 2470 | "node_modules/signal-exit": { 2471 | "version": "3.0.2", 2472 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2473 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2474 | "dev": true 2475 | }, 2476 | "node_modules/simple-update-notifier": { 2477 | "version": "1.1.0", 2478 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.1.0.tgz", 2479 | "integrity": "sha512-VpsrsJSUcJEseSbMHkrsrAVSdvVS5I96Qo1QAQ4FxQ9wXFcB+pjj7FB7/us9+GcgfW4ziHtYMc1J0PLczb55mg==", 2480 | "dev": true, 2481 | "dependencies": { 2482 | "semver": "~7.0.0" 2483 | }, 2484 | "engines": { 2485 | "node": ">=8.10.0" 2486 | } 2487 | }, 2488 | "node_modules/simple-update-notifier/node_modules/semver": { 2489 | "version": "7.0.0", 2490 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 2491 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", 2492 | "dev": true, 2493 | "bin": { 2494 | "semver": "bin/semver.js" 2495 | } 2496 | }, 2497 | "node_modules/slice-ansi": { 2498 | "version": "2.1.0", 2499 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2500 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2501 | "dev": true, 2502 | "dependencies": { 2503 | "ansi-styles": "^3.2.0", 2504 | "astral-regex": "^1.0.0", 2505 | "is-fullwidth-code-point": "^2.0.0" 2506 | }, 2507 | "engines": { 2508 | "node": ">=6" 2509 | } 2510 | }, 2511 | "node_modules/slice-ansi/node_modules/is-fullwidth-code-point": { 2512 | "version": "2.0.0", 2513 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2514 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2515 | "dev": true, 2516 | "engines": { 2517 | "node": ">=4" 2518 | } 2519 | }, 2520 | "node_modules/sliced": { 2521 | "version": "1.0.1", 2522 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 2523 | "integrity": "sha512-VZBmZP8WU3sMOZm1bdgTadsQbcscK0UM8oKxKVBs4XAhUo2Xxzm/OFMGBkPusxw9xL3Uy8LrzEqGqJhclsr0yA==" 2524 | }, 2525 | "node_modules/sparse-bitfield": { 2526 | "version": "3.0.3", 2527 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 2528 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 2529 | "optional": true, 2530 | "dependencies": { 2531 | "memory-pager": "^1.0.2" 2532 | } 2533 | }, 2534 | "node_modules/sprintf-js": { 2535 | "version": "1.0.3", 2536 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2537 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2538 | "dev": true 2539 | }, 2540 | "node_modules/sshpk": { 2541 | "version": "1.16.1", 2542 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 2543 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 2544 | "dependencies": { 2545 | "asn1": "~0.2.3", 2546 | "assert-plus": "^1.0.0", 2547 | "bcrypt-pbkdf": "^1.0.0", 2548 | "dashdash": "^1.12.0", 2549 | "ecc-jsbn": "~0.1.1", 2550 | "getpass": "^0.1.1", 2551 | "jsbn": "~0.1.0", 2552 | "safer-buffer": "^2.0.2", 2553 | "tweetnacl": "~0.14.0" 2554 | }, 2555 | "bin": { 2556 | "sshpk-conv": "bin/sshpk-conv", 2557 | "sshpk-sign": "bin/sshpk-sign", 2558 | "sshpk-verify": "bin/sshpk-verify" 2559 | }, 2560 | "engines": { 2561 | "node": ">=0.10.0" 2562 | } 2563 | }, 2564 | "node_modules/statuses": { 2565 | "version": "2.0.1", 2566 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 2567 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 2568 | "engines": { 2569 | "node": ">= 0.8" 2570 | } 2571 | }, 2572 | "node_modules/string_decoder": { 2573 | "version": "1.3.0", 2574 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 2575 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 2576 | "dev": true, 2577 | "dependencies": { 2578 | "safe-buffer": "~5.2.0" 2579 | } 2580 | }, 2581 | "node_modules/string-width": { 2582 | "version": "4.2.0", 2583 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 2584 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 2585 | "dev": true, 2586 | "dependencies": { 2587 | "emoji-regex": "^8.0.0", 2588 | "is-fullwidth-code-point": "^3.0.0", 2589 | "strip-ansi": "^6.0.0" 2590 | }, 2591 | "engines": { 2592 | "node": ">=8" 2593 | } 2594 | }, 2595 | "node_modules/string-width/node_modules/strip-ansi": { 2596 | "version": "6.0.0", 2597 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2598 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2599 | "dev": true, 2600 | "dependencies": { 2601 | "ansi-regex": "^5.0.0" 2602 | }, 2603 | "engines": { 2604 | "node": ">=8" 2605 | } 2606 | }, 2607 | "node_modules/strip-ansi": { 2608 | "version": "5.2.0", 2609 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2610 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2611 | "dev": true, 2612 | "dependencies": { 2613 | "ansi-regex": "^4.1.0" 2614 | }, 2615 | "engines": { 2616 | "node": ">=6" 2617 | } 2618 | }, 2619 | "node_modules/strip-ansi/node_modules/ansi-regex": { 2620 | "version": "4.1.1", 2621 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", 2622 | "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", 2623 | "dev": true, 2624 | "engines": { 2625 | "node": ">=6" 2626 | } 2627 | }, 2628 | "node_modules/strip-json-comments": { 2629 | "version": "3.0.1", 2630 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", 2631 | "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==", 2632 | "dev": true, 2633 | "engines": { 2634 | "node": ">=8" 2635 | } 2636 | }, 2637 | "node_modules/superagent": { 2638 | "version": "5.1.1", 2639 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-5.1.1.tgz", 2640 | "integrity": "sha512-bpTO/3yQsHPH5w6f7qPCWGTuhEV2w93fwFGpYODnUc5tPa3rmbHUCmwC7iuEFBQQJsyhiW1WVc/ISpfAEv6ojQ==", 2641 | "deprecated": "Please upgrade to v7.0.2+ of superagent. We have fixed numerous issues with streams, form-data, attach(), filesystem errors not bubbling up (ENOENT on attach()), and all tests are now passing. See the releases tab for more information at .", 2642 | "dev": true, 2643 | "dependencies": { 2644 | "component-emitter": "^1.3.0", 2645 | "cookiejar": "^2.1.2", 2646 | "debug": "^4.1.1", 2647 | "fast-safe-stringify": "^2.0.6", 2648 | "form-data": "^2.3.3", 2649 | "formidable": "^1.2.1", 2650 | "methods": "^1.1.2", 2651 | "mime": "^2.4.4", 2652 | "qs": "^6.7.0", 2653 | "readable-stream": "^3.4.0", 2654 | "semver": "^6.1.1" 2655 | }, 2656 | "engines": { 2657 | "node": ">= 7.0.0" 2658 | } 2659 | }, 2660 | "node_modules/supports-color": { 2661 | "version": "5.5.0", 2662 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2663 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2664 | "dev": true, 2665 | "dependencies": { 2666 | "has-flag": "^3.0.0" 2667 | }, 2668 | "engines": { 2669 | "node": ">=4" 2670 | } 2671 | }, 2672 | "node_modules/table": { 2673 | "version": "5.4.6", 2674 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 2675 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 2676 | "dev": true, 2677 | "dependencies": { 2678 | "ajv": "^6.10.2", 2679 | "lodash": "^4.17.14", 2680 | "slice-ansi": "^2.1.0", 2681 | "string-width": "^3.0.0" 2682 | }, 2683 | "engines": { 2684 | "node": ">=6.0.0" 2685 | } 2686 | }, 2687 | "node_modules/table/node_modules/emoji-regex": { 2688 | "version": "7.0.3", 2689 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2690 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2691 | "dev": true 2692 | }, 2693 | "node_modules/table/node_modules/is-fullwidth-code-point": { 2694 | "version": "2.0.0", 2695 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2696 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2697 | "dev": true, 2698 | "engines": { 2699 | "node": ">=4" 2700 | } 2701 | }, 2702 | "node_modules/table/node_modules/string-width": { 2703 | "version": "3.1.0", 2704 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2705 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2706 | "dev": true, 2707 | "dependencies": { 2708 | "emoji-regex": "^7.0.1", 2709 | "is-fullwidth-code-point": "^2.0.0", 2710 | "strip-ansi": "^5.1.0" 2711 | }, 2712 | "engines": { 2713 | "node": ">=6" 2714 | } 2715 | }, 2716 | "node_modules/text-table": { 2717 | "version": "0.2.0", 2718 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2719 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2720 | "dev": true 2721 | }, 2722 | "node_modules/through": { 2723 | "version": "2.3.8", 2724 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2725 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2726 | "dev": true 2727 | }, 2728 | "node_modules/tmp": { 2729 | "version": "0.0.33", 2730 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2731 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2732 | "dev": true, 2733 | "dependencies": { 2734 | "os-tmpdir": "~1.0.2" 2735 | }, 2736 | "engines": { 2737 | "node": ">=0.6.0" 2738 | } 2739 | }, 2740 | "node_modules/to-regex-range": { 2741 | "version": "5.0.1", 2742 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2743 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2744 | "dev": true, 2745 | "dependencies": { 2746 | "is-number": "^7.0.0" 2747 | }, 2748 | "engines": { 2749 | "node": ">=8.0" 2750 | } 2751 | }, 2752 | "node_modules/toidentifier": { 2753 | "version": "1.0.1", 2754 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 2755 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 2756 | "engines": { 2757 | "node": ">=0.6" 2758 | } 2759 | }, 2760 | "node_modules/touch": { 2761 | "version": "3.1.0", 2762 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2763 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2764 | "dev": true, 2765 | "dependencies": { 2766 | "nopt": "~1.0.10" 2767 | }, 2768 | "bin": { 2769 | "nodetouch": "bin/nodetouch.js" 2770 | } 2771 | }, 2772 | "node_modules/tough-cookie": { 2773 | "version": "2.5.0", 2774 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 2775 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 2776 | "dependencies": { 2777 | "psl": "^1.1.28", 2778 | "punycode": "^2.1.1" 2779 | }, 2780 | "engines": { 2781 | "node": ">=0.8" 2782 | } 2783 | }, 2784 | "node_modules/tslib": { 2785 | "version": "1.10.0", 2786 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 2787 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==", 2788 | "dev": true 2789 | }, 2790 | "node_modules/tunnel-agent": { 2791 | "version": "0.6.0", 2792 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 2793 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 2794 | "dependencies": { 2795 | "safe-buffer": "^5.0.1" 2796 | }, 2797 | "engines": { 2798 | "node": "*" 2799 | } 2800 | }, 2801 | "node_modules/tweetnacl": { 2802 | "version": "0.14.5", 2803 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 2804 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" 2805 | }, 2806 | "node_modules/type-check": { 2807 | "version": "0.3.2", 2808 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2809 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2810 | "dev": true, 2811 | "dependencies": { 2812 | "prelude-ls": "~1.1.2" 2813 | }, 2814 | "engines": { 2815 | "node": ">= 0.8.0" 2816 | } 2817 | }, 2818 | "node_modules/type-fest": { 2819 | "version": "0.8.1", 2820 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2821 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2822 | "dev": true, 2823 | "engines": { 2824 | "node": ">=8" 2825 | } 2826 | }, 2827 | "node_modules/type-is": { 2828 | "version": "1.6.18", 2829 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2830 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2831 | "dependencies": { 2832 | "media-typer": "0.3.0", 2833 | "mime-types": "~2.1.24" 2834 | }, 2835 | "engines": { 2836 | "node": ">= 0.6" 2837 | } 2838 | }, 2839 | "node_modules/undefsafe": { 2840 | "version": "2.0.5", 2841 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 2842 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 2843 | "dev": true 2844 | }, 2845 | "node_modules/universal-analytics": { 2846 | "version": "0.4.20", 2847 | "resolved": "https://registry.npmjs.org/universal-analytics/-/universal-analytics-0.4.20.tgz", 2848 | "integrity": "sha512-gE91dtMvNkjO+kWsPstHRtSwHXz0l2axqptGYp5ceg4MsuurloM0PU3pdOfpb5zBXUvyjT4PwhWK2m39uczZuw==", 2849 | "dependencies": { 2850 | "debug": "^3.0.0", 2851 | "request": "^2.88.0", 2852 | "uuid": "^3.0.0" 2853 | } 2854 | }, 2855 | "node_modules/universal-analytics/node_modules/debug": { 2856 | "version": "3.2.6", 2857 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 2858 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 2859 | "deprecated": "Debug versions >=3.2.0 <3.2.7 || >=4 <4.3.1 have a low-severity ReDos regression when used in a Node.js environment. It is recommended you upgrade to 3.2.7 or 4.3.1. (https://github.com/visionmedia/debug/issues/797)", 2860 | "dependencies": { 2861 | "ms": "^2.1.1" 2862 | } 2863 | }, 2864 | "node_modules/unpipe": { 2865 | "version": "1.0.0", 2866 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2867 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 2868 | "engines": { 2869 | "node": ">= 0.8" 2870 | } 2871 | }, 2872 | "node_modules/uri-js": { 2873 | "version": "4.2.2", 2874 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2875 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2876 | "dependencies": { 2877 | "punycode": "^2.1.0" 2878 | } 2879 | }, 2880 | "node_modules/url": { 2881 | "version": "0.11.0", 2882 | "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", 2883 | "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", 2884 | "dependencies": { 2885 | "punycode": "1.3.2", 2886 | "querystring": "0.2.0" 2887 | } 2888 | }, 2889 | "node_modules/url/node_modules/punycode": { 2890 | "version": "1.3.2", 2891 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 2892 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" 2893 | }, 2894 | "node_modules/util-deprecate": { 2895 | "version": "1.0.2", 2896 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2897 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2898 | }, 2899 | "node_modules/utils-merge": { 2900 | "version": "1.0.1", 2901 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2902 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 2903 | "engines": { 2904 | "node": ">= 0.4.0" 2905 | } 2906 | }, 2907 | "node_modules/uuid": { 2908 | "version": "3.4.0", 2909 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 2910 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 2911 | "deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.", 2912 | "bin": { 2913 | "uuid": "bin/uuid" 2914 | } 2915 | }, 2916 | "node_modules/v8-compile-cache": { 2917 | "version": "2.1.0", 2918 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", 2919 | "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", 2920 | "dev": true 2921 | }, 2922 | "node_modules/vary": { 2923 | "version": "1.1.2", 2924 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2925 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 2926 | "engines": { 2927 | "node": ">= 0.8" 2928 | } 2929 | }, 2930 | "node_modules/verror": { 2931 | "version": "1.10.0", 2932 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2933 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2934 | "engines": [ 2935 | "node >=0.6.0" 2936 | ], 2937 | "dependencies": { 2938 | "assert-plus": "^1.0.0", 2939 | "core-util-is": "1.0.2", 2940 | "extsprintf": "^1.2.0" 2941 | } 2942 | }, 2943 | "node_modules/which": { 2944 | "version": "1.3.1", 2945 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2946 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2947 | "dev": true, 2948 | "dependencies": { 2949 | "isexe": "^2.0.0" 2950 | }, 2951 | "bin": { 2952 | "which": "bin/which" 2953 | } 2954 | }, 2955 | "node_modules/word-wrap": { 2956 | "version": "1.2.3", 2957 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2958 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2959 | "dev": true, 2960 | "engines": { 2961 | "node": ">=0.10.0" 2962 | } 2963 | }, 2964 | "node_modules/wrappy": { 2965 | "version": "1.0.2", 2966 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2967 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2968 | "dev": true 2969 | }, 2970 | "node_modules/write": { 2971 | "version": "1.0.3", 2972 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2973 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2974 | "dev": true, 2975 | "dependencies": { 2976 | "mkdirp": "^0.5.1" 2977 | }, 2978 | "engines": { 2979 | "node": ">=4" 2980 | } 2981 | } 2982 | } 2983 | } 2984 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "api-tutorial", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "server.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "node server.js", 9 | "start:watch": "nodemon server.js", 10 | "seed": "node seed.js", 11 | "drop": "mongo stranger-things --eval 'db.dropDatabase()'", 12 | "db-load-all": "npm run drop && npm run seed" 13 | }, 14 | "repository": { 15 | "type": "git", 16 | "url": "git+https://github.com/paigeegorry/api-tutorial.git" 17 | }, 18 | "keywords": [], 19 | "author": "", 20 | "license": "ISC", 21 | "bugs": { 22 | "url": "https://github.com/paigeegorry/api-tutorial/issues" 23 | }, 24 | "homepage": "https://github.com/paigeegorry/api-tutorial#readme", 25 | "devDependencies": { 26 | "eslint": "^6.7.0", 27 | "node-html-parser": "^1.1.16", 28 | "nodemon": "^2.0.1", 29 | "superagent": "^5.1.1" 30 | }, 31 | "dependencies": { 32 | "cors": "^2.8.5", 33 | "dotenv": "^8.2.0", 34 | "express": "^4.17.1", 35 | "express-ga-middleware": "^0.1.6", 36 | "mongoose": "^5.9.2", 37 | "url": "^0.11.0" 38 | } 39 | } 40 | -------------------------------------------------------------------------------- /scrapers/infoScraper.js: -------------------------------------------------------------------------------- 1 | const { parse } = require('node-html-parser'); 2 | const request = require('superagent'); 3 | const nameScraper = require('./nameScraper') 4 | const { reformatData, getDataToFormat } = require('./utils') 5 | 6 | const infoScraper = async() => { 7 | const names = await nameScraper() 8 | 9 | try { 10 | return Promise.all( 11 | names.map(name => { 12 | return request.get(`https://strangerthings.fandom.com/wiki/${name}`) 13 | .then(res => res.text) 14 | .then(parse) 15 | .then(html => getDataToFormat(html, name)) 16 | .then(reformatData) 17 | .catch(err => console.log({ name, err })) 18 | })) 19 | } 20 | catch(err) { 21 | console.error(err) 22 | } 23 | }; 24 | 25 | module.exports = infoScraper; 26 | -------------------------------------------------------------------------------- /scrapers/nameScraper.js: -------------------------------------------------------------------------------- 1 | const { parse } = require('node-html-parser'); 2 | const request = require('superagent'); 3 | 4 | module.exports = () => { 5 | return request.get(`https://strangerthings.fandom.com/wiki/Category:Characters`) 6 | .then(res => res.text) 7 | .then(parse) 8 | .then(findCharLink) 9 | .then(findCharNames) 10 | }; 11 | 12 | const findCharLink = html => html.querySelectorAll('.category-page__member-link'); 13 | const findCharNames = objs => { 14 | const names = objs.map(obj => obj.childNodes[0].rawText); 15 | return names.filter(name => !name.includes('Category:') && !name.includes('Minor Characters') && !name.includes('Character List')); 16 | }; 17 | 18 | -------------------------------------------------------------------------------- /scrapers/utils.js: -------------------------------------------------------------------------------- 1 | const lodash = require('lodash'); 2 | 3 | const cleanUp = str => str.replace(':', '').trim(); 4 | const removeSymbol = arr => arr.map(str => str && (str.includes('†') ? str.replace('†', '').trim() : str.trim())) 5 | const removeHtmlTags = str => ( 6 | str.replace('', '') 7 | .replace('', '') 8 | .replace('

', '') 9 | .replace('

', '') 10 | .replace('
', '') 11 | .replace('
', '') 12 | ); 13 | const genFinalValue = (label, val) => { 14 | if(['otherRelations', 'aliases', 'appearsInEpisodes', 'occupation', 'affiliation'].includes(label)) { 15 | return val instanceof Array ? val : [val] 16 | } else { 17 | return val instanceof Array ? val[0] : val 18 | } 19 | }; 20 | 21 | const getDataToFormat = (html, name) => { 22 | const labels = html.querySelectorAll('.pi-data-label').map(l => l.structuredText) 23 | const values = html.querySelectorAll('div .pi-data-value') 24 | const photoInfo = html.querySelectorAll('.pi-image-thumbnail').length 25 | ? html.querySelectorAll('.pi-image-thumbnail')[0].rawAttrs.split('"')[1] 26 | : 'https://upload.wikimedia.org/wikipedia/commons/3/38/Stranger_Things_logo.png' // default logo image 27 | return { labels, values, photoInfo, name }; 28 | } 29 | 30 | const reformatData = ({ labels, values, photoInfo, name }) => { 31 | if(labels.length === values.length) { 32 | const obj = {}; 33 | obj.photo = photoInfo; 34 | obj.name = name; 35 | return labels.reduce((acc, l, i) => { 36 | const label = lodash.camelCase(l) 37 | const value = values[i].text 38 | const htmlVal = values[i].innerHTML 39 | 40 | // label === 'residence' ? console.log({ value, htmlVal }) : null 41 | 42 | if(label === 'appearsInEpisodes') { 43 | let newVal = value.trim().split(' ').map(s => s.replace(',', '')) 44 | acc[label] = genFinalValue(label, newVal) 45 | } 46 | else if(htmlVal.includes('') && !htmlVal.includes(' s).map(s => s.includes('(') ? s + ')' : s) 48 | acc[label] = genFinalValue(label, newVal) 49 | } 50 | else if(htmlVal.includes('').map(str => str.trim()) 53 | .filter(str => str[0] !== '<' && str[0] !== '/' && str.length > 0 && !str.includes('(formerly)')) 54 | .map(str => str.replace(' { 56 | if(str.includes(' s)) 60 | } 61 | else if(!htmlVal.includes('') 63 | .filter(s => s).map(s => removeHtmlTags(s)) 64 | newVal = removeSymbol(newVal) 65 | acc[label] = genFinalValue(label, newVal) 66 | } 67 | else { 68 | let newVal = htmlVal.split('>').map(str => str.trim()) 69 | .filter(str => str[0] !== '<' && str[0] !== '/' && str.length > 0 && !str.includes('(')) 70 | .map(str => str.replace(' !str.includes(' { 73 | if(str.includes(' s) 77 | acc[label] = genFinalValue(label, newVal) 78 | } 79 | } 80 | else if(value.includes(')') && label !== 'height') { 81 | let newVal = value.split(')').map(s => s.length > 0 ? (s + ')').trim() : undefined).filter(s => s && s !== ')') 82 | if(label === 'residence') { 83 | if(htmlVal.includes('
  • ')) { 84 | newVal = value.split(')').map(s => s.includes('(') ? cleanUp(s) + ')' : cleanUp(s)).filter(s => s) 85 | acc[label] = newVal 86 | } else { 87 | newVal = newVal.map(s => cleanUp(s)) 88 | acc[label] = genFinalValue(label, value) 89 | } 90 | } 91 | else { 92 | newVal = removeSymbol(newVal.map(s => cleanUp(s))) 93 | acc[label] = genFinalValue(label, value) 94 | } 95 | } 96 | else { 97 | acc[label] = genFinalValue(label, value) 98 | } 99 | return acc; 100 | }, obj); 101 | } 102 | else undefined 103 | }; 104 | 105 | module.exports = { 106 | reformatData, 107 | getDataToFormat 108 | } 109 | 110 | -------------------------------------------------------------------------------- /seed.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config(); 2 | require('./lib/utils/connect')(); 3 | const scrapeData = require('./scrapers/infoScraper'); 4 | const Character = require('./lib/Models/Character'); 5 | const mongoose = require('mongoose'); 6 | 7 | scrapeData() 8 | .then(chars => Character.create(chars)) 9 | .finally(() => mongoose.connection.close()); -------------------------------------------------------------------------------- /server.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config(); 2 | require('./lib/utils/connect')(); 3 | const app = require('./lib/app'); 4 | 5 | const PORT = process.env.PORT || 8080; 6 | 7 | app.get('/', function(req, res){ 8 | res.redirect('https://strangerthingsapi.netlify.app/docs'); 9 | }); 10 | 11 | app.listen(PORT, () => { 12 | console.log(`listening at PORT ${PORT}`); 13 | }); 14 | --------------------------------------------------------------------------------