├── .gitignore
├── README.md
├── api
├── psql-con.js
└── routes
│ ├── entries.js
│ ├── userFunctions.js
│ ├── users.js
│ └── verifyToken.js
├── client
├── .gitignore
├── README.md
├── package-lock.json
├── package.json
├── public
│ ├── favicon.ico
│ ├── index.html
│ └── manifest.json
└── src
│ ├── App.css
│ ├── App.css.map
│ ├── App.js
│ ├── App.scss
│ ├── actions
│ ├── pageActions.js
│ └── userActions.js
│ ├── components
│ ├── Entry.js
│ ├── Footer.js
│ ├── Home.js
│ ├── Nav.js
│ ├── ProtectedRoute.js
│ └── forms
│ │ ├── NewEntry.js
│ │ ├── SignIn.js
│ │ └── SignUp.js
│ ├── images
│ ├── Envelope.png
│ └── GitHub.png
│ ├── index.js
│ ├── reducers
│ ├── index.js
│ ├── pageReducer.js
│ └── userReducer.js
│ └── serviceWorker.js
├── dotenv_example
├── index.js
├── package-lock.json
├── package.json
└── screenshots
├── entry-example.png
├── home-page.png
├── new-entry.png
├── sign-in.png
└── sign-up.png
/.gitignore:
--------------------------------------------------------------------------------
1 | .env
2 | node_modules/
3 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # react-blog
2 | Open source blog built with:
3 | - **React** for creating a SPA
4 | - **Redux** for global state
5 | - **Express** for making back-end development easier
6 | - **bcryptjs** for hashing passwords
7 | - **JWT** for token creation and authentication
8 | - **node-postgres** for connecting to the database (PostgreSQL)
9 | - **SASS** for better css organization and readability
10 |
11 | ## Screenshots
12 | 
13 | 
14 | 
15 | 
16 | 
17 |
18 | ## Features
19 | - Create and read entries
20 | - Create users
21 | - Hashed passwords
22 | - Token authentication
23 | - Protected routes
24 | - Sanitized inputs
25 | - Entry content accepts html tags so that the user has power to add images, lists and so forth
26 |
27 | ## How to install
28 |
29 | Step 1: installing dependencies
30 | ```bash
31 | git clone https://github.com/alochaus/react-blog.git
32 | cd react-blog/
33 |
34 | #install server dependencies
35 | npm i
36 |
37 | #install client dependencies
38 | cd client/
39 | npm i
40 |
41 | cd ..
42 |
43 | #if you want to run ONLY the server
44 | npm run server
45 |
46 | #if you want to run ONLY the client
47 | npm run client
48 |
49 | #if you want to run BOTH
50 | npm run dev
51 | ```
52 |
53 | Step 2: creating tables in database
54 | ```
55 | CREATE TABLE entries(
56 | header char(50) NOT NULL,
57 | subheader char(300) NOT NULL,
58 | cateogry char(100) NOT NULL,
59 | content text NOT NULL,
60 | author char(50) NOT NULL,
61 | date char(20) NOT NULL
62 | );
63 | CREATE TABLE users(
64 | email char(100) NOT NULL,
65 | username char(20) NOT NULL,
66 | hash text NOT NULL
67 | );
68 | ```
69 |
70 | Step 3: setting environment variables
71 | Fill the dotenv_example with database information, create a jwtsecretkey and then save the file as ".env".
72 |
73 | Example:
74 | ```
75 | PGUSER=Josh
76 | PGPASSWORD=mysupersecretpassword
77 | PGDATABASE=blog
78 | PGPORT=5432
79 | PGHOST=myhostname
80 | JWTSECRETKEY=as8dhj0a98sfh
81 | ```
82 |
83 |
--------------------------------------------------------------------------------
/api/psql-con.js:
--------------------------------------------------------------------------------
1 | const {Pool} = require('pg');
2 | const pool = new Pool({
3 | user: process.env.PGUSER,
4 | host: process.env.PGHOST,
5 | database: process.env.PGDATABASE,
6 | password: process.env.PGPASSWORD,
7 | port: process.env.PGPORT,
8 | });
9 |
10 | pool.connect((err, client, release) => {
11 | if (err) {
12 | return console.error('Error acquiring client', err.stack)
13 | }
14 | client.query('SELECT NOW()', (err, result) => {
15 | release()
16 | if (err) {
17 | return console.error('Error executing query', err.stack)
18 | }
19 | console.log(result.rows)
20 | })
21 | });
22 |
23 | module.exports = {
24 | query: (text, params, callback) => {
25 | return pool.query(text, params, callback)
26 | }
27 | }
28 |
--------------------------------------------------------------------------------
/api/routes/entries.js:
--------------------------------------------------------------------------------
1 | const router = require("express").Router();
2 | const db = require("../psql-con.js");
3 | const verify = require("./verifyToken.js");
4 |
5 | router.get("/:title", async (req, res) => {
6 | const { title } = req.params;
7 | const regex = /^[\w\s-!?'‘’.,()<>:\[\]]+$/;
8 | if (regex.test(title)) {
9 | const header = title.replace(/-/g, "");
10 | const {
11 | rows
12 | } = await db.query("SELECT * FROM entries WHERE LOWER(header)=LOWER($1)", [
13 | header
14 | ]);
15 | if (rows.length) {
16 | res.status(200).send(rows);
17 | } else {
18 | res.status(204).send([]);
19 | }
20 | } else {
21 | res.status(400).send([]);
22 | }
23 | });
24 |
25 | router.get("/page/:page", async (req, res) => {
26 | const entriesPerPage = 6;
27 | const offset = (Number(req.params.page) - 1) * entriesPerPage;
28 | if (typeof offset == "number" && offset >= 0) {
29 | let {
30 | rows
31 | } = await db.query(
32 | "SELECT * FROM (SELECT *, ROW_NUMBER() OVER() FROM entries) x ORDER BY ROW_NUMBER DESC OFFSET $1 ROWS FETCH FIRST $2 ROWS ONLY",
33 | [offset, entriesPerPage]
34 | );
35 | rows.map((row, index) => {
36 | let url = row.header;
37 | link = url.toLowerCase().replace(/\s/g, "-");
38 | rows[index].link = link;
39 | });
40 | res.status(200).send(await rows);
41 | } else {
42 | res.status(204).send([]);
43 | }
44 | });
45 |
46 | router.post("/new", verify, async (req, res) => {
47 | const { header, subheader, category, content } = req.body;
48 | const author = req.user.username;
49 |
50 | const date = new Date();
51 | const hhmm =
52 | String(date.getHours()).padStart(2, "0") +
53 | ":" +
54 | String(date.getMinutes()).padStart(2, "0");
55 |
56 | const dd = String(date.getDate()).padStart(2, "0");
57 | const mm = String(date.getMonth() + 1).padStart(2, "0");
58 | const yy = String(date.getFullYear()).padStart(2, "0");
59 |
60 | const dateStr = dd + "/" + mm + "/" + yy + " " + hhmm;
61 |
62 | if (
63 | header.trim() != "" &&
64 | subheader.trim() != "" &&
65 | category.trim() != "" &&
66 | content.trim() != ""
67 | ) {
68 | const {
69 | rows
70 | } = await db.query("INSERT INTO entries VALUES($1, $2, $3, $4, $5, $6)", [
71 | header,
72 | subheader,
73 | category,
74 | content,
75 | author,
76 | dateStr
77 | ]);
78 | res.status(201).send({ msg: "Your entry has been added to the database." });
79 | } else {
80 | res.status(400).send({ msg: "Please fill all the fields." });
81 | }
82 | });
83 |
84 | module.exports = router;
85 |
--------------------------------------------------------------------------------
/api/routes/userFunctions.js:
--------------------------------------------------------------------------------
1 | const db = require('../psql-con.js');
2 |
3 | module.exports = {
4 | // returns true if the input inserted by the user meets the requirements in the form.
5 | validUser: (email, username, password) => {
6 | const emailRegEx = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
7 | const validEmail = emailRegEx.test(email);
8 |
9 | const validUsername = typeof username == 'string' && username.trim().length > 2;
10 |
11 | // minimum eight characters, at least one uppercase letter, one lowercase letter and one number
12 | const passwordRegEx = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)[a-zA-Z\d]{8,}$/;
13 | const validPassword = passwordRegEx.test(password);
14 | return validEmail && validUsername && validPassword;
15 | },
16 |
17 | // returns true if email exists
18 | emailExists: async (email) => {
19 | const {rows} = await db.query('SELECT email FROM users WHERE email = $1', [email]);
20 | if(rows.length === 0){
21 | return false;
22 | }
23 | return true;
24 | },
25 |
26 | // returns true if username exists
27 | usernameExists: async (username) => {
28 | const {rows} = await db.query('SELECT username FROM users WHERE username = $1', [username]);
29 | if(rows.length === 0){
30 | return false;
31 | }
32 | return true;
33 | }
34 | }
35 |
--------------------------------------------------------------------------------
/api/routes/users.js:
--------------------------------------------------------------------------------
1 | const router = require('express').Router();
2 | const bcrypt = require('bcryptjs');
3 | const db = require('../psql-con.js');
4 | const jwt = require('jsonwebtoken');
5 | const verify = require('./verifyToken.js');
6 | const {validUser, emailExists, usernameExists} = require('./userFunctions.js');
7 |
8 | router.post('/signup', async (req, res) => {
9 | const {email, username, password, c_password} = req.body;
10 | var err = [];
11 | if(validUser(email, username, password)){
12 | const emailResponse = await emailExists(email);
13 | err = emailResponse ? [...err, "This email is already in use."] : [...err];
14 |
15 | const usernameResponse = await usernameExists(username)
16 | err = usernameResponse ? [...err, "This username is already in use."] : [...err];
17 |
18 | if(Object.keys(err).length === 0){
19 | const hash = bcrypt.hashSync(password, 10);
20 | await db.query('INSERT INTO users VALUES($1, $2, $3)', [email, username, hash]);
21 | res.status(201).send(["User successfully registered!"])
22 | } else{
23 | res.status(400).send(err);
24 | }
25 | } else{
26 | res.status(400).send(["Inputted data does not meet the requirements."]);
27 | }
28 | });
29 |
30 | router.post('/signin', async (req, res) => {
31 | const {email, password} = req.body;
32 | const emailResponse = await emailExists(email);
33 | if(!emailResponse){
34 | res.status(401).send({msg:"Email or password is incorrect."});
35 | } else{
36 | const {rows} = await db.query('SELECT username, email, hash FROM users WHERE email = $1', [email]);
37 | const hash = rows[0].hash;
38 | if(bcrypt.compareSync(password, hash)){
39 | const {email, username} = rows[0];
40 | const token = jwt.sign({username, email}, process.env.JWTSECRETKEY, {expiresIn:"1h"});
41 | res.status(200).send({"token":token, user:{username, email}});
42 | } else{
43 | res.status(401).send({msg:"Email or password is incorrect."});
44 | }
45 | }
46 | });
47 |
48 | router.post('/isLogged', verify, async (req, res) => {
49 | res.status(200).send({isLogged:true, email: req.user.email, username: req.user.username});
50 | });
51 |
52 | module.exports = router;
53 |
--------------------------------------------------------------------------------
/api/routes/verifyToken.js:
--------------------------------------------------------------------------------
1 | const jwt = require('jsonwebtoken');
2 |
3 | module.exports = (req, res, next) => {
4 | const {token} = req.body;
5 | const tokenRegEx = /^[A-Za-z0-9-_=]+\.[A-Za-z0-9-_=]+\.?[A-Za-z0-9-_.+/=]*$/;
6 | if(!token) return res.status(401);
7 | if(tokenRegEx.test(token)){
8 | try{
9 | const verified = jwt.verify(token, process.env.JWTSECRETKEY);
10 | req.user = verified;
11 | next();
12 | } catch(err){
13 | res.status(401).send({isLogged:false, email:'', username:''});
14 | }
15 | } else{
16 | res.status(401).send({isLogged:false, email:'', username:''});
17 | }
18 | };
19 |
--------------------------------------------------------------------------------
/client/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2 |
3 | # dependencies
4 | /node_modules
5 | /.pnp
6 | .pnp.js
7 |
8 | # testing
9 | /coverage
10 |
11 | # production
12 | /build
13 |
14 | # misc
15 | .DS_Store
16 | .env.local
17 | .env.development.local
18 | .env.test.local
19 | .env.production.local
20 |
21 | npm-debug.log*
22 | yarn-debug.log*
23 | yarn-error.log*
24 |
--------------------------------------------------------------------------------
/client/README.md:
--------------------------------------------------------------------------------
1 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app).
2 |
3 | ## Available Scripts
4 |
5 | In the project directory, you can run:
6 |
7 | ### `npm start`
8 |
9 | Runs the app in the development mode.
10 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
11 |
12 | The page will reload if you make edits.
13 | You will also see any lint errors in the console.
14 |
15 | ### `npm test`
16 |
17 | Launches the test runner in the interactive watch mode.
18 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
19 |
20 | ### `npm run build`
21 |
22 | Builds the app for production to the `build` folder.
23 | It correctly bundles React in production mode and optimizes the build for the best performance.
24 |
25 | The build is minified and the filenames include the hashes.
26 | Your app is ready to be deployed!
27 |
28 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
29 |
30 | ### `npm run eject`
31 |
32 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!**
33 |
34 | If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project.
35 |
36 | Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own.
37 |
38 | You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it.
39 |
40 | ## Learn More
41 |
42 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started).
43 |
44 | To learn React, check out the [React documentation](https://reactjs.org/).
45 |
46 | ### Code Splitting
47 |
48 | This section has moved here: https://facebook.github.io/create-react-app/docs/code-splitting
49 |
50 | ### Analyzing the Bundle Size
51 |
52 | This section has moved here: https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size
53 |
54 | ### Making a Progressive Web App
55 |
56 | This section has moved here: https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app
57 |
58 | ### Advanced Configuration
59 |
60 | This section has moved here: https://facebook.github.io/create-react-app/docs/advanced-configuration
61 |
62 | ### Deployment
63 |
64 | This section has moved here: https://facebook.github.io/create-react-app/docs/deployment
65 |
66 | ### `npm run build` fails to minify
67 |
68 | This section has moved here: https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify
69 |
--------------------------------------------------------------------------------
/client/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "client",
3 | "version": "0.1.0",
4 | "private": true,
5 | "dependencies": {
6 | "react": "^16.8.6",
7 | "react-dom": "^16.8.6",
8 | "react-redux": "^7.1.0",
9 | "react-router": "^5.0.1",
10 | "react-router-dom": "^5.0.1",
11 | "react-scripts": "^3.4.1",
12 | "redux": "^4.0.4",
13 | "redux-logger": "^3.0.6",
14 | "redux-thunk": "^2.3.0"
15 | },
16 | "scripts": {
17 | "start": "react-scripts start",
18 | "build": "react-scripts build",
19 | "test": "react-scripts test",
20 | "eject": "react-scripts eject"
21 | },
22 | "eslintConfig": {
23 | "extends": "react-app"
24 | },
25 | "browserslist": {
26 | "production": [
27 | ">0.2%",
28 | "not dead",
29 | "not op_mini all"
30 | ],
31 | "development": [
32 | "last 1 chrome version",
33 | "last 1 firefox version",
34 | "last 1 safari version"
35 | ]
36 | },
37 | "proxy": "http://localhost:5000"
38 | }
39 |
--------------------------------------------------------------------------------
/client/public/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/client/public/favicon.ico
--------------------------------------------------------------------------------
/client/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
14 |
15 |
24 | React App
25 |
26 |
27 |
28 |
29 |
39 |
40 |
41 |
--------------------------------------------------------------------------------
/client/public/manifest.json:
--------------------------------------------------------------------------------
1 | {
2 | "short_name": "React App",
3 | "name": "Create React App Sample",
4 | "icons": [
5 | {
6 | "src": "favicon.ico",
7 | "sizes": "64x64 32x32 24x24 16x16",
8 | "type": "image/x-icon"
9 | }
10 | ],
11 | "start_url": ".",
12 | "display": "standalone",
13 | "theme_color": "#000000",
14 | "background_color": "#ffffff"
15 | }
16 |
--------------------------------------------------------------------------------
/client/src/App.css:
--------------------------------------------------------------------------------
1 | * {
2 | margin: 0;
3 | padding: 0;
4 | text-align: center;
5 | }
6 |
7 | body {
8 | background-color: #eee;
9 | }
10 |
11 | .navbar {
12 | display: flex;
13 | justify-content: space-between;
14 | align-items: center;
15 | background-color: #024cb5;
16 | color: #fff;
17 | }
18 | .navbar ul {
19 | display: flex;
20 | }
21 | .navbar li {
22 | display: block;
23 | list-style: none;
24 | padding: 1rem;
25 | }
26 | .navbar a {
27 | color: #fff;
28 | font-size: 10pt;
29 | font-weight: bold;
30 | text-decoration: none;
31 | }
32 |
33 | .title {
34 | margin: 0.5rem;
35 | }
36 | .title h1 > a {
37 | text-decoration: none;
38 | font-size: 25pt;
39 | color: white;
40 | }
41 |
42 | .footer {
43 | position: fixed;
44 | bottom: 0;
45 | width: 100%;
46 | height: 40px;
47 | background-color: #024cb5;
48 | }
49 | .footer a img {
50 | height: 80%;
51 | transform: translateY(13%);
52 | padding-right: 10px;
53 | }
54 | .footer a .envelope {
55 | height: 50%;
56 | transform: translateY(-5%);
57 | }
58 |
59 | .togglebtn {
60 | cursor: pointer;
61 | position: absolute;
62 | font-size: 25pt;
63 | display: none;
64 | top: 0.7rem;
65 | right: 0.5rem;
66 | }
67 |
68 | .entry {
69 | margin: 0 auto;
70 | margin-top: 10px;
71 | padding: 15px;
72 | width: 700px;
73 | border: 3px solid #f7f7f7;
74 | border-radius: 10px;
75 | background-color: #fff;
76 | }
77 | .entry div {
78 | text-align: left;
79 | margin-bottom: 50px;
80 | }
81 | .entry div ul {
82 | margin-left: 20px;
83 | }
84 | .entry div ul ul {
85 | margin-left: 15px;
86 | }
87 | .entry div ul li {
88 | text-align: left;
89 | }
90 | .entry div img {
91 | margin: 20px auto;
92 | width: 100%;
93 | }
94 | .entry div p {
95 | margin: 10px 0;
96 | }
97 | .entry a {
98 | text-decoration: none;
99 | }
100 | .entry p {
101 | text-align: left;
102 | }
103 | .entry .header {
104 | font-size: 20pt;
105 | font-weight: bold;
106 | color: #024cb5;
107 | }
108 | .entry .subheader {
109 | font-size: 15pt;
110 | color: #111;
111 | }
112 | .entry .category {
113 | font-size: 8pt;
114 | margin-top: 1px;
115 | color: #333;
116 | }
117 | .entry .author {
118 | float: right;
119 | font-size: 8pt;
120 | }
121 | .entry .date {
122 | font-size: 8pt;
123 | }
124 |
125 | .mfooter {
126 | margin-bottom: 70px;
127 | }
128 |
129 | .page-btn {
130 | cursor: pointer;
131 | border: 3px solid #024cb5;
132 | background: #fff;
133 | color: #024cb5;
134 | padding: 10px 20px;
135 | letter-spacing: 3px;
136 | transition: 0.5s;
137 | }
138 | .page-btn:hover {
139 | border: 3px solid #9dc0fa;
140 | color: #9dc0fa;
141 | }
142 |
143 | .form {
144 | margin: 10px auto;
145 | margin-bottom: 60px;
146 | padding: 12px;
147 | width: 50%;
148 | border: 3px solid #f7f7f7;
149 | border-radius: 10px;
150 | background-color: #fff;
151 | }
152 | .form .newEntry input[type=text] {
153 | width: 50%;
154 | }
155 | .form .requirements {
156 | border: 3px solid #9dc0fa;
157 | border-radius: 10px;
158 | background-color: #c2d7f9;
159 | margin-bottom: 10px;
160 | }
161 | .form .requirements h2 {
162 | padding-top: 10px;
163 | margin-bottom: 10px;
164 | }
165 | .form .requirements ul {
166 | padding-left: 20px;
167 | padding-bottom: 10px;
168 | }
169 | .form .requirements ul li {
170 | text-align: left;
171 | }
172 | .form h1 {
173 | font-size: 24px;
174 | text-align: left;
175 | color: #14171a;
176 | padding-bottom: 15px;
177 | }
178 | .form form {
179 | padding-right: 12px;
180 | text-align: left;
181 | border-radius: none;
182 | }
183 | .form form input, .form form textarea {
184 | margin-bottom: 10px;
185 | font-size: 11pt;
186 | text-align: left;
187 | }
188 | .form form textarea {
189 | box-shadow: none;
190 | width: 99.5%;
191 | height: 240px;
192 | padding: 7px;
193 | }
194 |
195 | @media (max-width: 769px) {
196 | .togglebtn {
197 | display: flex;
198 | }
199 |
200 | .links {
201 | display: none;
202 | width: 100%;
203 | }
204 |
205 | .active {
206 | display: block;
207 | }
208 |
209 | .navbar {
210 | align-items: flex-start;
211 | flex-direction: column;
212 | }
213 |
214 | .navbar ul {
215 | flex-direction: column;
216 | width: 100%;
217 | }
218 | .navbar ul li:hover {
219 | background-color: #1f86fc;
220 | }
221 |
222 | .entry, .form {
223 | width: 84.7%;
224 | }
225 | }
226 |
227 | /*# sourceMappingURL=App.css.map */
228 |
--------------------------------------------------------------------------------
/client/src/App.css.map:
--------------------------------------------------------------------------------
1 | {"version":3,"sourceRoot":"","sources":["App.scss"],"names":[],"mappings":"AAcA;EACE;EACA;EACA;;;AAGF;EACE,kBAbW;;;AAgBb;EACE;EACA;EACA;EACA,kBA3BU;EA4BV,OAvBS;;AAwBT;EACE;;AAEF;EACE;EACA;EACA;;AAEF;EACE,OAjCO;EAkCP;EACA;EACA;;;AAIJ;EACE;;AACA;EACE;EACF;EACE;;;AAIJ;EACE;EACA;EACA;EACA;EACA,kBA3DU;;AA6DR;EACE;EACA;EACA;;AAEF;EACE;EACA;;;AAKN;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA,kBApFS;;AAqFT;EACE;EACA;;AACA;EACE;;AACA;EACE;;AAEF;EACE;;AAGJ;EACE;EACA;;AAEF;EACE;;AAIJ;EACE;;AAGF;EACE;;AAGF;EACE;EACA;EACA,OA1HQ;;AA6HV;EACE;EACA,OArHO;;AAwHT;EACE;EACA;EACA,OA1HO;;AA6HT;EACE;EACA;;AAEF;EACE;;;AAIJ;EACE;;;AAGF;EACE;EACA;EACA,YAnJS;EAoJT,OAzJU;EA0JV;EACA;EACA;;AAEA;EACE;EACA,OA9JS;;;AAkKb;EACE;EACA;EACA;EACA;EACA;EACA;EACA,kBAtKS;;AAyKP;EACE;;AAIJ;EAYE;EACA;EACA;EACA;;AAdA;EACE;EACA;;AAEF;EACE;EACA;;AACA;EACA;;AASJ;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;;AAKN;EACE;IACE;;;EAEF;IACE;IACA;;;EAEF;IACE;;;EAEF;IACE;IACA;;;EAEF;IACE;IACA;;EAEA;IACE,kBAjPQ;;;EAqPZ;IACE","file":"App.css"}
--------------------------------------------------------------------------------
/client/src/App.js:
--------------------------------------------------------------------------------
1 | import React, {useEffect} from 'react';
2 | import {BrowserRouter as Router, Route, Switch} from 'react-router-dom';
3 | import {useDispatch} from 'react-redux';
4 | import {verifyToken} from './actions/userActions.js'
5 |
6 | import './App.css';
7 |
8 | /* COMPONENTS */
9 | import {PrivateRoute} from './components/ProtectedRoute.js';
10 | import Home from './components/Home.js';
11 | import Entry from './components/Entry.js';
12 | import Nav from './components/Nav.js';
13 | import Footer from './components/Footer.js';
14 | import SignIn from './components/forms/SignIn.js';
15 | import SignUp from './components/forms/SignUp.js';
16 | import NewEntry from './components/forms/NewEntry.js';
17 |
18 | export default function App() {
19 | const dispatch = useDispatch();
20 |
21 | useEffect(() => {
22 | dispatch(verifyToken());
23 | }, [dispatch])
24 |
25 | return (
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 | );
41 | }
42 |
--------------------------------------------------------------------------------
/client/src/App.scss:
--------------------------------------------------------------------------------
1 | $colourOne: #00134e;
2 | $colourTwo: #024cb5;
3 | $colourThree: #1f86fc;
4 | $colourFour: #9dc0fa;
5 | $colourFive: #e8dacd;
6 |
7 | $whiteOne: #fff;
8 | $whiteTwo: #f7f7f7;
9 | $whiteThree: #eee;
10 | $whiteFour: #dcdcdc;
11 |
12 | $blackOne: #111;
13 | $blackTwo: #333;
14 |
15 | *{
16 | margin:0;
17 | padding:0;
18 | text-align:center;
19 | }
20 |
21 | body{
22 | background-color:$whiteThree;
23 | }
24 |
25 | .navbar{
26 | display:flex;
27 | justify-content:space-between;
28 | align-items:center;
29 | background-color:$colourTwo;
30 | color:$whiteOne;
31 | ul{
32 | display:flex;
33 | }
34 | li{
35 | display:block;
36 | list-style:none;
37 | padding:1rem;
38 | }
39 | a{
40 | color:$whiteOne;
41 | font-size:10pt;
42 | font-weight:bold;
43 | text-decoration:none;
44 | }
45 | }
46 |
47 | .title{
48 | margin:.5rem;
49 | h1 > a{
50 | text-decoration:none;
51 | font-size:25pt;
52 | color:white;
53 | }
54 | }
55 |
56 | .footer{
57 | position:fixed;
58 | bottom:0;
59 | width:100%;
60 | height:40px;
61 | background-color:$colourTwo;
62 | a{
63 | img{
64 | height:80%;
65 | transform: translateY(13%);
66 | padding-right:10px;
67 | }
68 | .envelope{
69 | height:50%;
70 | transform: translateY(-5%);
71 | }
72 | }
73 | }
74 |
75 | .togglebtn{
76 | cursor:pointer;
77 | position:absolute;
78 | font-size:25pt;
79 | display:none;
80 | top:0.7rem;
81 | right:0.5rem;
82 | }
83 |
84 | .entry{
85 | margin:0 auto;
86 | margin-top:10px;
87 | padding:15px;
88 | width:700px;
89 | border:3px solid $whiteTwo;
90 | border-radius:10px;
91 | background-color:$whiteOne;
92 | div{
93 | text-align:left;
94 | margin-bottom:50px;
95 | ul{
96 | margin-left:20px;
97 | ul{
98 | margin-left:15px;
99 | }
100 | li{
101 | text-align:left
102 | }
103 | }
104 | img{
105 | margin:20px auto;
106 | width:100%;
107 | }
108 | p{
109 | margin:10px 0;
110 | }
111 | }
112 |
113 | a{
114 | text-decoration:none;
115 | }
116 |
117 | p{
118 | text-align:left;
119 | }
120 |
121 | .header{
122 | font-size:20pt;
123 | font-weight:bold;
124 | color:$colourTwo;
125 | }
126 |
127 | .subheader{
128 | font-size:15pt;
129 | color:$blackOne;
130 | }
131 |
132 | .category{
133 | font-size:8pt;
134 | margin-top:1px;
135 | color:$blackTwo;
136 | }
137 |
138 | .author{
139 | float:right;
140 | font-size:8pt;
141 | }
142 | .date{
143 | font-size:8pt;
144 | }
145 | }
146 |
147 | .mfooter{
148 | margin-bottom:70px;
149 | }
150 |
151 | .page-btn{
152 | cursor:pointer;
153 | border:3px solid $colourTwo;
154 | background:$whiteOne;
155 | color:$colourTwo;
156 | padding:10px 20px;
157 | letter-spacing:3px;
158 | transition:0.5s;
159 |
160 | &:hover{
161 | border:3px solid $colourFour;
162 | color:$colourFour;
163 | }
164 | }
165 |
166 | .form{
167 | margin:10px auto;
168 | margin-bottom:60px;
169 | padding:12px;
170 | width:50%;
171 | border:3px solid $whiteTwo;
172 | border-radius:10px;
173 | background-color:$whiteOne;
174 |
175 | .newEntry{
176 | input[type=text]{
177 | width:50%;
178 | }
179 | }
180 |
181 | .requirements{
182 | h2{
183 | padding-top:10px;
184 | margin-bottom:10px;
185 | }
186 | ul{
187 | padding-left:20px;
188 | padding-bottom:10px;
189 | li{
190 | text-align:left;
191 | }
192 | }
193 | border:3px solid $colourFour;
194 | border-radius:10px;
195 | background-color:#c2d7f9;
196 | margin-bottom:10px;
197 | }
198 |
199 | h1{
200 | font-size:24px;
201 | text-align:left;
202 | color:#14171a;
203 | padding-bottom:15px;
204 | }
205 | form{
206 | padding-right:12px;
207 | text-align:left;
208 | border-radius:none;
209 |
210 | input, textarea{
211 | margin-bottom:10px;
212 | font-size:11pt;
213 | text-align:left;
214 | }
215 | textarea{
216 | box-shadow:none;
217 | width:99.5%;
218 | height:240px;
219 | padding:7px;
220 | }
221 | }
222 | }
223 |
224 | @media(max-width:769px){
225 | .togglebtn{
226 | display:flex;
227 | }
228 | .links{
229 | display:none;
230 | width:100%;
231 | }
232 | .active{
233 | display:block;
234 | }
235 | .navbar{
236 | align-items:flex-start;
237 | flex-direction:column;
238 | }
239 | .navbar ul{
240 | flex-direction:column;
241 | width:100%;
242 |
243 | li:hover{
244 | background-color:$colourThree;
245 | }
246 | }
247 |
248 | .entry, .form{
249 | width:84.7%;
250 | }
251 | }
252 |
--------------------------------------------------------------------------------
/client/src/actions/pageActions.js:
--------------------------------------------------------------------------------
1 | export const setPage = (payload) => {
2 | if(typeof payload === 'number'){
3 | return{type:'SET_PAGE', payload};
4 | } else{
5 | return{type:'SET_PAGE', payload:0};
6 | }
7 | };
8 |
--------------------------------------------------------------------------------
/client/src/actions/userActions.js:
--------------------------------------------------------------------------------
1 | export const verifyToken = () => {
2 | return dispatch => {
3 | fetch('/api/user/isLogged', {
4 | method:'POST',
5 | headers:{'Content-Type':'application/json'},
6 | body:JSON.stringify({token: localStorage.getItem('token')})
7 | })
8 | .then((res) => res.json())
9 | .then((payload) => dispatch({type: 'VERIFY', payload}));
10 | }
11 | }
12 |
13 | export const signOut = () => {
14 | return{type:'SIGN_OUT'};
15 | }
16 |
--------------------------------------------------------------------------------
/client/src/components/Entry.js:
--------------------------------------------------------------------------------
1 | import React, {useState, useEffect} from 'react';
2 |
3 | export default function(props){
4 | const [entry, setEntry] = useState({});
5 |
6 | useEffect(() => {
7 | const fetchEntry = async () => {
8 | let res = await fetch(`/api/entries/${props.match.params.id}`);
9 | res = await res.json();
10 | setEntry({...res[0]});
11 | }
12 | fetchEntry();
13 | }, [props.match.params.id]);
14 |
15 | const displayEntry =
16 |
17 |
{entry.header}
18 |
{entry.subheader}
19 |
{entry.category}
20 |
21 |
Written by: {entry.author}
22 |
{entry.date}
23 |
24 |
25 | return(
26 | <>
27 | {displayEntry}
28 | >
29 | );
30 | }
31 |
--------------------------------------------------------------------------------
/client/src/components/Footer.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import GitHub from '../images/GitHub.png';
3 | import Envelope from '../images/Envelope.png';
4 |
5 | export default function Footer(){
6 | return(
7 |
8 |

9 |

10 |
11 | );
12 | }
13 |
14 |
--------------------------------------------------------------------------------
/client/src/components/Home.js:
--------------------------------------------------------------------------------
1 | import React, {useState, useEffect} from 'react';
2 | import {Link} from 'react-router-dom';
3 | import {useSelector, useDispatch} from 'react-redux';
4 | import {setPage} from '../actions/pageActions.js';
5 |
6 | export default function Home(props){
7 | const [entries, setEntries] = useState([]);
8 | const dispatch = useDispatch();
9 | const page = useSelector(state => state.pageReducer);
10 |
11 | useEffect(() => {
12 | const fetchEntries = async () => {
13 | let res = await fetch(`/api/entries/page/${page}`);
14 | res = await res.json();
15 | setEntries([...res]);
16 | };
17 |
18 | fetchEntries();
19 | }, [page]);
20 |
21 | const lastEntry = entries[entries.length - 1];
22 |
23 | const displayEntries = entries.map((entries) =>
24 |
25 |
{entries.header}
26 |
{entries.subheader}
27 |
{entries.category}
28 |
Written by: {entries.author}
29 |
{entries.date}
30 |
31 | );
32 |
33 | const displayPrevBtn = (lastEntry === undefined || page === 1) ?
34 | null : dispatch(setPage(page - 1))}>;
35 |
36 | const displayNextBtn = (lastEntry === undefined || lastEntry.row_number === '1') ?
37 | null : dispatch(setPage(page + 1))}>;
38 |
39 | return(
40 | <>
41 | {displayEntries}
42 |
43 |
44 | {displayPrevBtn}{displayNextBtn}
45 |
46 | >
47 | );
48 | }
49 |
--------------------------------------------------------------------------------
/client/src/components/Nav.js:
--------------------------------------------------------------------------------
1 | import React, {useState} from 'react';
2 | import {Link} from 'react-router-dom';
3 | import {useSelector, useDispatch} from 'react-redux';
4 | import {signOut} from '../actions/userActions.js';
5 |
6 | import {setPage} from '../actions/pageActions.js';
7 |
8 | function Nav(){
9 | const [active, setActive] = useState(false);
10 | const dispatch = useDispatch();
11 | const isLogged = useSelector((state) => state.userReducer.isLogged);
12 | const hamburger = () => {
13 | setActive(!active);
14 | };
15 | const removeToken = async () => {
16 | await setActive(false);
17 | localStorage.removeItem('token');
18 | dispatch(signOut());
19 | }
20 |
21 | const links = (!isLogged) ? (
22 | <>
23 | setActive(false)}>Sign in
24 | setActive(false)}>Sign up>
25 | ) : (
26 | <>
27 | setActive(false)}>New Entry
28 | Sign out>
29 | );
30 |
31 | const isActive = (active) ? (" active") : ("");
32 |
33 | return(
34 |
35 |
52 |
53 | );
54 | }
55 |
56 | export default Nav;
57 |
--------------------------------------------------------------------------------
/client/src/components/ProtectedRoute.js:
--------------------------------------------------------------------------------
1 | import React, {useEffect} from 'react';
2 | import {Route} from 'react-router-dom';
3 | import SignIn from './forms/SignIn';
4 | import {useSelector, useDispatch} from 'react-redux';
5 | import {verifyToken} from '../actions/userActions.js'
6 |
7 | export const PrivateRoute = ({component: Component, ...rest}) => {
8 | const dispatch = useDispatch();
9 | const isLogged = useSelector(state => state.userReducer.isLogged);
10 |
11 |
12 | useEffect(() => {
13 | dispatch(verifyToken());
14 | }, [dispatch]);
15 |
16 | return(
17 | (isLogged) ? :
19 | } />
20 | );
21 | };
22 |
--------------------------------------------------------------------------------
/client/src/components/forms/NewEntry.js:
--------------------------------------------------------------------------------
1 | import React, {useState} from 'react';
2 |
3 | export default function SignIn(){
4 | const [data, setData] = useState({
5 | header:"",
6 | subheader:"",
7 | category:"",
8 | content:"",
9 | msg:"",
10 | });
11 |
12 | const onChange = (event) => {
13 | setData({...data, [event.target.name]: event.target.value});
14 | };
15 |
16 | const onSubmit = async (event) => {
17 | event.preventDefault();
18 | const {header, subheader, category, content} = data;
19 | let res = await fetch('/api/entries/new', {method:'POST', headers:{'Content-Type':'application/json'}, body:JSON.stringify({token:localStorage.getItem('token'), header, subheader, category, content})});
20 | res = await res.json();
21 | setData({...data, msg:res.msg, header:"", subheader:"", category:"", content:""});
22 | }
23 |
24 | const result = (data.msg) ? ({data.msg}
) : null;
25 |
26 | return(
27 |
28 |
New Entry
29 |
41 |
42 | );
43 | }
44 |
--------------------------------------------------------------------------------
/client/src/components/forms/SignIn.js:
--------------------------------------------------------------------------------
1 | import React, {useState} from 'react';
2 | import {useDispatch} from 'react-redux';
3 | import {verifyToken} from '../../actions/userActions.js';
4 |
5 | export default function SignIn(props){
6 | const [data, setData] = useState({
7 | email:"",
8 | password:"",
9 | msg:""
10 | });
11 | const dispatch = useDispatch();
12 | const onChange = (event) => {
13 | setData({...data, [event.target.name]: event.target.value});
14 | };
15 |
16 | const onSubmit = async (event) => {
17 | event.preventDefault();
18 | const {email, password} = data;
19 | let res = await fetch('/api/user/signin', {method:'POST', headers:{'Content-type':'application/json'}, body:JSON.stringify({email, password})})
20 | res = await res.json();
21 | if(res.msg){
22 | setData({email:"", password:"", msg:res.msg});
23 | } else{
24 | localStorage.setItem('token', res.token);
25 | dispatch(verifyToken());
26 | props.history.push('/');
27 | }
28 | }
29 | /*
30 | .then((res) => res.json(res)).then((res) => {
31 | if(Object.keys(res).includes('msg')){
32 | setData({email:"", password:"", msg: res.msg});
33 | } else{
34 | localStorage.setItem('token', res.token);
35 | dispatch(verifyToken());
36 | props.history.push('/');
37 | }
38 | });
39 | */
40 | const result = (data.msg) ? ({data.msg}
) : null;
41 |
42 | return(
43 |
44 |
Sign in
45 |
53 |
54 | );
55 | }
56 |
--------------------------------------------------------------------------------
/client/src/components/forms/SignUp.js:
--------------------------------------------------------------------------------
1 | import React, {useState} from 'react';
2 |
3 | export default function SignUn(){
4 | const [data, setData] = useState({
5 | email:"",
6 | username:"",
7 | password:"",
8 | c_password:"",
9 | msg:[]
10 | });
11 |
12 | const onChange = (event) => {
13 | setData({...data, [event.target.name]: event.target.value});
14 | };
15 | const onSubmit = async (event) => {
16 | event.preventDefault();
17 | const {email, username, password, c_password} = data;
18 | if(password === c_password){
19 | let res = await fetch('/api/user/signup', {method:'POST', headers:{'Content-type':'application/json'}, body:JSON.stringify({email, username, password, c_password})});
20 | res = await res.json();
21 |
22 | setData({
23 | email:"",
24 | username:"",
25 | password:"",
26 | c_password:"",
27 | msg:[...res]
28 | });
29 | } else{
30 | setData({
31 | ...data,
32 | password:"",
33 | c_password:"",
34 | msg:["Passwords don't match."]
35 | });
36 | }
37 | };
38 |
39 | const result = (data.msg) ? data.msg.map((msg) => {msg}
) : null;
40 | return(
41 |
63 | );
64 | }
65 |
--------------------------------------------------------------------------------
/client/src/images/Envelope.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/client/src/images/Envelope.png
--------------------------------------------------------------------------------
/client/src/images/GitHub.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/client/src/images/GitHub.png
--------------------------------------------------------------------------------
/client/src/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import ReactDOM from 'react-dom';
3 | import App from './App';
4 | import * as serviceWorker from './serviceWorker';
5 | import {createStore, applyMiddleware, compose} from 'redux';
6 | import rootReducer from './reducers';
7 | import {Provider} from 'react-redux';
8 | import thunk from 'redux-thunk';
9 | import logger from 'redux-logger';
10 |
11 | const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose;
12 | const store = createStore(rootReducer, composeEnhancers(applyMiddleware(thunk, logger)));
13 |
14 | ReactDOM.render(, document.getElementById('root'));
15 |
16 | // If you want your app to work offline and load faster, you can change
17 | // unregister() to register() below. Note this comes with some pitfalls.
18 | // Learn more about service workers: https://bit.ly/CRA-PWA
19 | serviceWorker.unregister();
20 |
--------------------------------------------------------------------------------
/client/src/reducers/index.js:
--------------------------------------------------------------------------------
1 | import {combineReducers} from 'redux';
2 | import userReducer from './userReducer.js';
3 | import pageReducer from './pageReducer.js';
4 |
5 | export default combineReducers({
6 | userReducer,
7 | pageReducer
8 | });
9 |
10 |
--------------------------------------------------------------------------------
/client/src/reducers/pageReducer.js:
--------------------------------------------------------------------------------
1 | const initialState = 1;
2 |
3 | const pageReducer = (state = initialState, {type, payload}) => {
4 | switch(type){
5 | case 'SET_PAGE':
6 | return payload;
7 | default:
8 | return state;
9 | }
10 | };
11 |
12 | export default pageReducer;
13 |
--------------------------------------------------------------------------------
/client/src/reducers/userReducer.js:
--------------------------------------------------------------------------------
1 | const initialState = {
2 | username: "",
3 | email: "",
4 | isLogged: false
5 | };
6 |
7 | const userReducer = (state = initialState, {type, payload}) => {
8 | switch(type){
9 | case 'VERIFY':
10 | return{
11 | ...state,
12 | username: payload.username,
13 | email: payload.email,
14 | isLogged: payload.isLogged
15 | };
16 | case 'SIGN_OUT':
17 | return{
18 | ...initialState
19 | }
20 | default:
21 | return state;
22 | }
23 | };
24 |
25 | export default userReducer;
26 |
--------------------------------------------------------------------------------
/client/src/serviceWorker.js:
--------------------------------------------------------------------------------
1 | // This optional code is used to register a service worker.
2 | // register() is not called by default.
3 |
4 | // This lets the app load faster on subsequent visits in production, and gives
5 | // it offline capabilities. However, it also means that developers (and users)
6 | // will only see deployed updates on subsequent visits to a page, after all the
7 | // existing tabs open on the page have been closed, since previously cached
8 | // resources are updated in the background.
9 |
10 | // To learn more about the benefits of this model and instructions on how to
11 | // opt-in, read https://bit.ly/CRA-PWA
12 |
13 | const isLocalhost = Boolean(
14 | window.location.hostname === 'localhost' ||
15 | // [::1] is the IPv6 localhost address.
16 | window.location.hostname === '[::1]' ||
17 | // 127.0.0.1/8 is considered localhost for IPv4.
18 | window.location.hostname.match(
19 | /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/
20 | )
21 | );
22 |
23 | export function register(config) {
24 | if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {
25 | // The URL constructor is available in all browsers that support SW.
26 | const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);
27 | if (publicUrl.origin !== window.location.origin) {
28 | // Our service worker won't work if PUBLIC_URL is on a different origin
29 | // from what our page is served on. This might happen if a CDN is used to
30 | // serve assets; see https://github.com/facebook/create-react-app/issues/2374
31 | return;
32 | }
33 |
34 | window.addEventListener('load', () => {
35 | const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;
36 |
37 | if (isLocalhost) {
38 | // This is running on localhost. Let's check if a service worker still exists or not.
39 | checkValidServiceWorker(swUrl, config);
40 |
41 | // Add some additional logging to localhost, pointing developers to the
42 | // service worker/PWA documentation.
43 | navigator.serviceWorker.ready.then(() => {
44 | console.log(
45 | 'This web app is being served cache-first by a service ' +
46 | 'worker. To learn more, visit https://bit.ly/CRA-PWA'
47 | );
48 | });
49 | } else {
50 | // Is not localhost. Just register service worker
51 | registerValidSW(swUrl, config);
52 | }
53 | });
54 | }
55 | }
56 |
57 | function registerValidSW(swUrl, config) {
58 | navigator.serviceWorker
59 | .register(swUrl)
60 | .then(registration => {
61 | registration.onupdatefound = () => {
62 | const installingWorker = registration.installing;
63 | if (installingWorker == null) {
64 | return;
65 | }
66 | installingWorker.onstatechange = () => {
67 | if (installingWorker.state === 'installed') {
68 | if (navigator.serviceWorker.controller) {
69 | // At this point, the updated precached content has been fetched,
70 | // but the previous service worker will still serve the older
71 | // content until all client tabs are closed.
72 | console.log(
73 | 'New content is available and will be used when all ' +
74 | 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'
75 | );
76 |
77 | // Execute callback
78 | if (config && config.onUpdate) {
79 | config.onUpdate(registration);
80 | }
81 | } else {
82 | // At this point, everything has been precached.
83 | // It's the perfect time to display a
84 | // "Content is cached for offline use." message.
85 | console.log('Content is cached for offline use.');
86 |
87 | // Execute callback
88 | if (config && config.onSuccess) {
89 | config.onSuccess(registration);
90 | }
91 | }
92 | }
93 | };
94 | };
95 | })
96 | .catch(error => {
97 | console.error('Error during service worker registration:', error);
98 | });
99 | }
100 |
101 | function checkValidServiceWorker(swUrl, config) {
102 | // Check if the service worker can be found. If it can't reload the page.
103 | fetch(swUrl)
104 | .then(response => {
105 | // Ensure service worker exists, and that we really are getting a JS file.
106 | const contentType = response.headers.get('content-type');
107 | if (
108 | response.status === 404 ||
109 | (contentType != null && contentType.indexOf('javascript') === -1)
110 | ) {
111 | // No service worker found. Probably a different app. Reload the page.
112 | navigator.serviceWorker.ready.then(registration => {
113 | registration.unregister().then(() => {
114 | window.location.reload();
115 | });
116 | });
117 | } else {
118 | // Service worker found. Proceed as normal.
119 | registerValidSW(swUrl, config);
120 | }
121 | })
122 | .catch(() => {
123 | console.log(
124 | 'No internet connection found. App is running in offline mode.'
125 | );
126 | });
127 | }
128 |
129 | export function unregister() {
130 | if ('serviceWorker' in navigator) {
131 | navigator.serviceWorker.ready.then(registration => {
132 | registration.unregister();
133 | });
134 | }
135 | }
136 |
--------------------------------------------------------------------------------
/dotenv_example:
--------------------------------------------------------------------------------
1 | PGUSER=
2 | PGPASSWORD=
3 | PGDATABASE=
4 | PGPORT=
5 | PGHOST=
6 | JWTSECRETKEY=
7 |
--------------------------------------------------------------------------------
/index.js:
--------------------------------------------------------------------------------
1 | const dotenv = require('dotenv').config();
2 | const express = require('express');
3 | const bodyparser = require('body-parser');
4 |
5 | const app = express();
6 |
7 | app.use(bodyparser.json());
8 | app.use(bodyparser.urlencoded({extended:true}));
9 |
10 | app.use('/api/user', require('./api/routes/users.js'));
11 | app.use('/api/entries', require('./api/routes/entries.js'));
12 |
13 | const PORT = process.env.port || 5000;
14 |
15 | app.listen(PORT, () => console.log(`Server is running on ${PORT}`));
16 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "blog",
3 | "version": "1.0.0",
4 | "lockfileVersion": 1,
5 | "requires": true,
6 | "dependencies": {
7 | "abbrev": {
8 | "version": "1.1.1",
9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
11 | "dev": true
12 | },
13 | "accepts": {
14 | "version": "1.3.7",
15 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz",
16 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==",
17 | "requires": {
18 | "mime-types": "~2.1.24",
19 | "negotiator": "0.6.2"
20 | }
21 | },
22 | "ansi-align": {
23 | "version": "2.0.0",
24 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-2.0.0.tgz",
25 | "integrity": "sha1-w2rsy6VjuJzrVW82kPCx2eNUf38=",
26 | "dev": true,
27 | "requires": {
28 | "string-width": "^2.0.0"
29 | }
30 | },
31 | "ansi-regex": {
32 | "version": "3.0.0",
33 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz",
34 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=",
35 | "dev": true
36 | },
37 | "ansi-styles": {
38 | "version": "3.2.1",
39 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
40 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
41 | "dev": true,
42 | "requires": {
43 | "color-convert": "^1.9.0"
44 | }
45 | },
46 | "anymatch": {
47 | "version": "2.0.0",
48 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
49 | "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==",
50 | "dev": true,
51 | "requires": {
52 | "micromatch": "^3.1.4",
53 | "normalize-path": "^2.1.1"
54 | },
55 | "dependencies": {
56 | "normalize-path": {
57 | "version": "2.1.1",
58 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
59 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
60 | "dev": true,
61 | "requires": {
62 | "remove-trailing-separator": "^1.0.1"
63 | }
64 | }
65 | }
66 | },
67 | "arr-diff": {
68 | "version": "4.0.0",
69 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz",
70 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=",
71 | "dev": true
72 | },
73 | "arr-flatten": {
74 | "version": "1.1.0",
75 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz",
76 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==",
77 | "dev": true
78 | },
79 | "arr-union": {
80 | "version": "3.1.0",
81 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz",
82 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=",
83 | "dev": true
84 | },
85 | "array-flatten": {
86 | "version": "1.1.1",
87 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
88 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
89 | },
90 | "array-unique": {
91 | "version": "0.3.2",
92 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz",
93 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=",
94 | "dev": true
95 | },
96 | "assign-symbols": {
97 | "version": "1.0.0",
98 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz",
99 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=",
100 | "dev": true
101 | },
102 | "async-each": {
103 | "version": "1.0.3",
104 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz",
105 | "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==",
106 | "dev": true
107 | },
108 | "atob": {
109 | "version": "2.1.2",
110 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz",
111 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==",
112 | "dev": true
113 | },
114 | "balanced-match": {
115 | "version": "1.0.0",
116 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
117 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
118 | "dev": true
119 | },
120 | "base": {
121 | "version": "0.11.2",
122 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz",
123 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==",
124 | "dev": true,
125 | "requires": {
126 | "cache-base": "^1.0.1",
127 | "class-utils": "^0.3.5",
128 | "component-emitter": "^1.2.1",
129 | "define-property": "^1.0.0",
130 | "isobject": "^3.0.1",
131 | "mixin-deep": "^1.2.0",
132 | "pascalcase": "^0.1.1"
133 | },
134 | "dependencies": {
135 | "define-property": {
136 | "version": "1.0.0",
137 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
138 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
139 | "dev": true,
140 | "requires": {
141 | "is-descriptor": "^1.0.0"
142 | }
143 | },
144 | "is-accessor-descriptor": {
145 | "version": "1.0.0",
146 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
147 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
148 | "dev": true,
149 | "requires": {
150 | "kind-of": "^6.0.0"
151 | }
152 | },
153 | "is-data-descriptor": {
154 | "version": "1.0.0",
155 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
156 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
157 | "dev": true,
158 | "requires": {
159 | "kind-of": "^6.0.0"
160 | }
161 | },
162 | "is-descriptor": {
163 | "version": "1.0.2",
164 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
165 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
166 | "dev": true,
167 | "requires": {
168 | "is-accessor-descriptor": "^1.0.0",
169 | "is-data-descriptor": "^1.0.0",
170 | "kind-of": "^6.0.2"
171 | }
172 | }
173 | }
174 | },
175 | "bcryptjs": {
176 | "version": "2.4.3",
177 | "resolved": "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz",
178 | "integrity": "sha1-mrVie5PmBiH/fNrF2pczAn3x0Ms="
179 | },
180 | "binary-extensions": {
181 | "version": "1.13.1",
182 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz",
183 | "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==",
184 | "dev": true
185 | },
186 | "body-parser": {
187 | "version": "1.19.0",
188 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz",
189 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==",
190 | "requires": {
191 | "bytes": "3.1.0",
192 | "content-type": "~1.0.4",
193 | "debug": "2.6.9",
194 | "depd": "~1.1.2",
195 | "http-errors": "1.7.2",
196 | "iconv-lite": "0.4.24",
197 | "on-finished": "~2.3.0",
198 | "qs": "6.7.0",
199 | "raw-body": "2.4.0",
200 | "type-is": "~1.6.17"
201 | }
202 | },
203 | "boxen": {
204 | "version": "1.3.0",
205 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.3.0.tgz",
206 | "integrity": "sha512-TNPjfTr432qx7yOjQyaXm3dSR0MH9vXp7eT1BFSl/C51g+EFnOR9hTg1IreahGBmDNCehscshe45f+C1TBZbLw==",
207 | "dev": true,
208 | "requires": {
209 | "ansi-align": "^2.0.0",
210 | "camelcase": "^4.0.0",
211 | "chalk": "^2.0.1",
212 | "cli-boxes": "^1.0.0",
213 | "string-width": "^2.0.0",
214 | "term-size": "^1.2.0",
215 | "widest-line": "^2.0.0"
216 | },
217 | "dependencies": {
218 | "camelcase": {
219 | "version": "4.1.0",
220 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz",
221 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=",
222 | "dev": true
223 | }
224 | }
225 | },
226 | "brace-expansion": {
227 | "version": "1.1.11",
228 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
229 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
230 | "dev": true,
231 | "requires": {
232 | "balanced-match": "^1.0.0",
233 | "concat-map": "0.0.1"
234 | }
235 | },
236 | "braces": {
237 | "version": "2.3.2",
238 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
239 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
240 | "dev": true,
241 | "requires": {
242 | "arr-flatten": "^1.1.0",
243 | "array-unique": "^0.3.2",
244 | "extend-shallow": "^2.0.1",
245 | "fill-range": "^4.0.0",
246 | "isobject": "^3.0.1",
247 | "repeat-element": "^1.1.2",
248 | "snapdragon": "^0.8.1",
249 | "snapdragon-node": "^2.0.1",
250 | "split-string": "^3.0.2",
251 | "to-regex": "^3.0.1"
252 | },
253 | "dependencies": {
254 | "extend-shallow": {
255 | "version": "2.0.1",
256 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
257 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
258 | "dev": true,
259 | "requires": {
260 | "is-extendable": "^0.1.0"
261 | }
262 | }
263 | }
264 | },
265 | "buffer-equal-constant-time": {
266 | "version": "1.0.1",
267 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz",
268 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk="
269 | },
270 | "buffer-writer": {
271 | "version": "2.0.0",
272 | "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz",
273 | "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw=="
274 | },
275 | "bytes": {
276 | "version": "3.1.0",
277 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz",
278 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg=="
279 | },
280 | "cache-base": {
281 | "version": "1.0.1",
282 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz",
283 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==",
284 | "dev": true,
285 | "requires": {
286 | "collection-visit": "^1.0.0",
287 | "component-emitter": "^1.2.1",
288 | "get-value": "^2.0.6",
289 | "has-value": "^1.0.0",
290 | "isobject": "^3.0.1",
291 | "set-value": "^2.0.0",
292 | "to-object-path": "^0.3.0",
293 | "union-value": "^1.0.0",
294 | "unset-value": "^1.0.0"
295 | }
296 | },
297 | "camelcase": {
298 | "version": "5.3.1",
299 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
300 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
301 | "dev": true
302 | },
303 | "capture-stack-trace": {
304 | "version": "1.0.1",
305 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.1.tgz",
306 | "integrity": "sha512-mYQLZnx5Qt1JgB1WEiMCf2647plpGeQ2NMR/5L0HNZzGQo4fuSPnK+wjfPnKZV0aiJDgzmWqqkV/g7JD+DW0qw==",
307 | "dev": true
308 | },
309 | "chalk": {
310 | "version": "2.4.2",
311 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
312 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
313 | "dev": true,
314 | "requires": {
315 | "ansi-styles": "^3.2.1",
316 | "escape-string-regexp": "^1.0.5",
317 | "supports-color": "^5.3.0"
318 | },
319 | "dependencies": {
320 | "supports-color": {
321 | "version": "5.5.0",
322 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
323 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
324 | "dev": true,
325 | "requires": {
326 | "has-flag": "^3.0.0"
327 | }
328 | }
329 | }
330 | },
331 | "chokidar": {
332 | "version": "2.1.6",
333 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.6.tgz",
334 | "integrity": "sha512-V2jUo67OKkc6ySiRpJrjlpJKl9kDuG+Xb8VgsGzb+aEouhgS1D0weyPU4lEzdAcsCAvrih2J2BqyXqHWvVLw5g==",
335 | "dev": true,
336 | "requires": {
337 | "anymatch": "^2.0.0",
338 | "async-each": "^1.0.1",
339 | "braces": "^2.3.2",
340 | "fsevents": "^1.2.7",
341 | "glob-parent": "^3.1.0",
342 | "inherits": "^2.0.3",
343 | "is-binary-path": "^1.0.0",
344 | "is-glob": "^4.0.0",
345 | "normalize-path": "^3.0.0",
346 | "path-is-absolute": "^1.0.0",
347 | "readdirp": "^2.2.1",
348 | "upath": "^1.1.1"
349 | }
350 | },
351 | "ci-info": {
352 | "version": "1.6.0",
353 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz",
354 | "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==",
355 | "dev": true
356 | },
357 | "class-utils": {
358 | "version": "0.3.6",
359 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
360 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==",
361 | "dev": true,
362 | "requires": {
363 | "arr-union": "^3.1.0",
364 | "define-property": "^0.2.5",
365 | "isobject": "^3.0.0",
366 | "static-extend": "^0.1.1"
367 | },
368 | "dependencies": {
369 | "define-property": {
370 | "version": "0.2.5",
371 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
372 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
373 | "dev": true,
374 | "requires": {
375 | "is-descriptor": "^0.1.0"
376 | }
377 | }
378 | }
379 | },
380 | "cli-boxes": {
381 | "version": "1.0.0",
382 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz",
383 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=",
384 | "dev": true
385 | },
386 | "cliui": {
387 | "version": "4.1.0",
388 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz",
389 | "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==",
390 | "dev": true,
391 | "requires": {
392 | "string-width": "^2.1.1",
393 | "strip-ansi": "^4.0.0",
394 | "wrap-ansi": "^2.0.0"
395 | }
396 | },
397 | "code-point-at": {
398 | "version": "1.1.0",
399 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz",
400 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=",
401 | "dev": true
402 | },
403 | "collection-visit": {
404 | "version": "1.0.0",
405 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz",
406 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=",
407 | "dev": true,
408 | "requires": {
409 | "map-visit": "^1.0.0",
410 | "object-visit": "^1.0.0"
411 | }
412 | },
413 | "color-convert": {
414 | "version": "1.9.3",
415 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
416 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
417 | "dev": true,
418 | "requires": {
419 | "color-name": "1.1.3"
420 | }
421 | },
422 | "color-name": {
423 | "version": "1.1.3",
424 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
425 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
426 | "dev": true
427 | },
428 | "component-emitter": {
429 | "version": "1.3.0",
430 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz",
431 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==",
432 | "dev": true
433 | },
434 | "concat-map": {
435 | "version": "0.0.1",
436 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
437 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
438 | "dev": true
439 | },
440 | "concurrently": {
441 | "version": "4.1.0",
442 | "resolved": "https://registry.npmjs.org/concurrently/-/concurrently-4.1.0.tgz",
443 | "integrity": "sha512-pwzXCE7qtOB346LyO9eFWpkFJVO3JQZ/qU/feGeaAHiX1M3Rw3zgXKc5cZ8vSH5DGygkjzLFDzA/pwoQDkRNGg==",
444 | "dev": true,
445 | "requires": {
446 | "chalk": "^2.4.1",
447 | "date-fns": "^1.23.0",
448 | "lodash": "^4.17.10",
449 | "read-pkg": "^4.0.1",
450 | "rxjs": "^6.3.3",
451 | "spawn-command": "^0.0.2-1",
452 | "supports-color": "^4.5.0",
453 | "tree-kill": "^1.1.0",
454 | "yargs": "^12.0.1"
455 | }
456 | },
457 | "configstore": {
458 | "version": "3.1.2",
459 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.2.tgz",
460 | "integrity": "sha512-vtv5HtGjcYUgFrXc6Kx747B83MRRVS5R1VTEQoXvuP+kMI+if6uywV0nDGoiydJRy4yk7h9od5Og0kxx4zUXmw==",
461 | "dev": true,
462 | "requires": {
463 | "dot-prop": "^4.1.0",
464 | "graceful-fs": "^4.1.2",
465 | "make-dir": "^1.0.0",
466 | "unique-string": "^1.0.0",
467 | "write-file-atomic": "^2.0.0",
468 | "xdg-basedir": "^3.0.0"
469 | }
470 | },
471 | "content-disposition": {
472 | "version": "0.5.3",
473 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz",
474 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==",
475 | "requires": {
476 | "safe-buffer": "5.1.2"
477 | }
478 | },
479 | "content-type": {
480 | "version": "1.0.4",
481 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
482 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA=="
483 | },
484 | "cookie": {
485 | "version": "0.4.0",
486 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz",
487 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg=="
488 | },
489 | "cookie-signature": {
490 | "version": "1.0.6",
491 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
492 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
493 | },
494 | "copy-descriptor": {
495 | "version": "0.1.1",
496 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz",
497 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=",
498 | "dev": true
499 | },
500 | "core-util-is": {
501 | "version": "1.0.2",
502 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
503 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=",
504 | "dev": true
505 | },
506 | "create-error-class": {
507 | "version": "3.0.2",
508 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz",
509 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=",
510 | "dev": true,
511 | "requires": {
512 | "capture-stack-trace": "^1.0.0"
513 | }
514 | },
515 | "cross-spawn": {
516 | "version": "6.0.5",
517 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz",
518 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==",
519 | "dev": true,
520 | "requires": {
521 | "nice-try": "^1.0.4",
522 | "path-key": "^2.0.1",
523 | "semver": "^5.5.0",
524 | "shebang-command": "^1.2.0",
525 | "which": "^1.2.9"
526 | }
527 | },
528 | "crypto-random-string": {
529 | "version": "1.0.0",
530 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz",
531 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=",
532 | "dev": true
533 | },
534 | "date-fns": {
535 | "version": "1.30.1",
536 | "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-1.30.1.tgz",
537 | "integrity": "sha512-hBSVCvSmWC+QypYObzwGOd9wqdDpOt+0wl0KbU+R+uuZBS1jN8VsD1ss3irQDknRj5NvxiTF6oj/nDRnN/UQNw==",
538 | "dev": true
539 | },
540 | "debug": {
541 | "version": "2.6.9",
542 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
543 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
544 | "requires": {
545 | "ms": "2.0.0"
546 | }
547 | },
548 | "decamelize": {
549 | "version": "1.2.0",
550 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz",
551 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=",
552 | "dev": true
553 | },
554 | "decode-uri-component": {
555 | "version": "0.2.0",
556 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz",
557 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=",
558 | "dev": true
559 | },
560 | "deep-extend": {
561 | "version": "0.6.0",
562 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
563 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==",
564 | "dev": true
565 | },
566 | "define-property": {
567 | "version": "2.0.2",
568 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz",
569 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==",
570 | "dev": true,
571 | "requires": {
572 | "is-descriptor": "^1.0.2",
573 | "isobject": "^3.0.1"
574 | },
575 | "dependencies": {
576 | "is-accessor-descriptor": {
577 | "version": "1.0.0",
578 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
579 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
580 | "dev": true,
581 | "requires": {
582 | "kind-of": "^6.0.0"
583 | }
584 | },
585 | "is-data-descriptor": {
586 | "version": "1.0.0",
587 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
588 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
589 | "dev": true,
590 | "requires": {
591 | "kind-of": "^6.0.0"
592 | }
593 | },
594 | "is-descriptor": {
595 | "version": "1.0.2",
596 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
597 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
598 | "dev": true,
599 | "requires": {
600 | "is-accessor-descriptor": "^1.0.0",
601 | "is-data-descriptor": "^1.0.0",
602 | "kind-of": "^6.0.2"
603 | }
604 | }
605 | }
606 | },
607 | "depd": {
608 | "version": "1.1.2",
609 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
610 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak="
611 | },
612 | "destroy": {
613 | "version": "1.0.4",
614 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
615 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
616 | },
617 | "dot-prop": {
618 | "version": "4.2.0",
619 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz",
620 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==",
621 | "dev": true,
622 | "requires": {
623 | "is-obj": "^1.0.0"
624 | }
625 | },
626 | "dotenv": {
627 | "version": "8.0.0",
628 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.0.0.tgz",
629 | "integrity": "sha512-30xVGqjLjiUOArT4+M5q9sYdvuR4riM6yK9wMcas9Vbp6zZa+ocC9dp6QoftuhTPhFAiLK/0C5Ni2nou/Bk8lg==",
630 | "dev": true
631 | },
632 | "duplexer3": {
633 | "version": "0.1.4",
634 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
635 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=",
636 | "dev": true
637 | },
638 | "ecdsa-sig-formatter": {
639 | "version": "1.0.11",
640 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz",
641 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==",
642 | "requires": {
643 | "safe-buffer": "^5.0.1"
644 | }
645 | },
646 | "ee-first": {
647 | "version": "1.1.1",
648 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
649 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
650 | },
651 | "encodeurl": {
652 | "version": "1.0.2",
653 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
654 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k="
655 | },
656 | "end-of-stream": {
657 | "version": "1.4.1",
658 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz",
659 | "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==",
660 | "dev": true,
661 | "requires": {
662 | "once": "^1.4.0"
663 | }
664 | },
665 | "error-ex": {
666 | "version": "1.3.2",
667 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
668 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
669 | "dev": true,
670 | "requires": {
671 | "is-arrayish": "^0.2.1"
672 | }
673 | },
674 | "escape-html": {
675 | "version": "1.0.3",
676 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
677 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
678 | },
679 | "escape-string-regexp": {
680 | "version": "1.0.5",
681 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
682 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
683 | "dev": true
684 | },
685 | "etag": {
686 | "version": "1.8.1",
687 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
688 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc="
689 | },
690 | "execa": {
691 | "version": "1.0.0",
692 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz",
693 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==",
694 | "dev": true,
695 | "requires": {
696 | "cross-spawn": "^6.0.0",
697 | "get-stream": "^4.0.0",
698 | "is-stream": "^1.1.0",
699 | "npm-run-path": "^2.0.0",
700 | "p-finally": "^1.0.0",
701 | "signal-exit": "^3.0.0",
702 | "strip-eof": "^1.0.0"
703 | }
704 | },
705 | "expand-brackets": {
706 | "version": "2.1.4",
707 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz",
708 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=",
709 | "dev": true,
710 | "requires": {
711 | "debug": "^2.3.3",
712 | "define-property": "^0.2.5",
713 | "extend-shallow": "^2.0.1",
714 | "posix-character-classes": "^0.1.0",
715 | "regex-not": "^1.0.0",
716 | "snapdragon": "^0.8.1",
717 | "to-regex": "^3.0.1"
718 | },
719 | "dependencies": {
720 | "define-property": {
721 | "version": "0.2.5",
722 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
723 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
724 | "dev": true,
725 | "requires": {
726 | "is-descriptor": "^0.1.0"
727 | }
728 | },
729 | "extend-shallow": {
730 | "version": "2.0.1",
731 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
732 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
733 | "dev": true,
734 | "requires": {
735 | "is-extendable": "^0.1.0"
736 | }
737 | }
738 | }
739 | },
740 | "express": {
741 | "version": "4.17.1",
742 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz",
743 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==",
744 | "requires": {
745 | "accepts": "~1.3.7",
746 | "array-flatten": "1.1.1",
747 | "body-parser": "1.19.0",
748 | "content-disposition": "0.5.3",
749 | "content-type": "~1.0.4",
750 | "cookie": "0.4.0",
751 | "cookie-signature": "1.0.6",
752 | "debug": "2.6.9",
753 | "depd": "~1.1.2",
754 | "encodeurl": "~1.0.2",
755 | "escape-html": "~1.0.3",
756 | "etag": "~1.8.1",
757 | "finalhandler": "~1.1.2",
758 | "fresh": "0.5.2",
759 | "merge-descriptors": "1.0.1",
760 | "methods": "~1.1.2",
761 | "on-finished": "~2.3.0",
762 | "parseurl": "~1.3.3",
763 | "path-to-regexp": "0.1.7",
764 | "proxy-addr": "~2.0.5",
765 | "qs": "6.7.0",
766 | "range-parser": "~1.2.1",
767 | "safe-buffer": "5.1.2",
768 | "send": "0.17.1",
769 | "serve-static": "1.14.1",
770 | "setprototypeof": "1.1.1",
771 | "statuses": "~1.5.0",
772 | "type-is": "~1.6.18",
773 | "utils-merge": "1.0.1",
774 | "vary": "~1.1.2"
775 | }
776 | },
777 | "extend-shallow": {
778 | "version": "3.0.2",
779 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz",
780 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=",
781 | "dev": true,
782 | "requires": {
783 | "assign-symbols": "^1.0.0",
784 | "is-extendable": "^1.0.1"
785 | },
786 | "dependencies": {
787 | "is-extendable": {
788 | "version": "1.0.1",
789 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
790 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
791 | "dev": true,
792 | "requires": {
793 | "is-plain-object": "^2.0.4"
794 | }
795 | }
796 | }
797 | },
798 | "extglob": {
799 | "version": "2.0.4",
800 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz",
801 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==",
802 | "dev": true,
803 | "requires": {
804 | "array-unique": "^0.3.2",
805 | "define-property": "^1.0.0",
806 | "expand-brackets": "^2.1.4",
807 | "extend-shallow": "^2.0.1",
808 | "fragment-cache": "^0.2.1",
809 | "regex-not": "^1.0.0",
810 | "snapdragon": "^0.8.1",
811 | "to-regex": "^3.0.1"
812 | },
813 | "dependencies": {
814 | "define-property": {
815 | "version": "1.0.0",
816 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
817 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
818 | "dev": true,
819 | "requires": {
820 | "is-descriptor": "^1.0.0"
821 | }
822 | },
823 | "extend-shallow": {
824 | "version": "2.0.1",
825 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
826 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
827 | "dev": true,
828 | "requires": {
829 | "is-extendable": "^0.1.0"
830 | }
831 | },
832 | "is-accessor-descriptor": {
833 | "version": "1.0.0",
834 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
835 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
836 | "dev": true,
837 | "requires": {
838 | "kind-of": "^6.0.0"
839 | }
840 | },
841 | "is-data-descriptor": {
842 | "version": "1.0.0",
843 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
844 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
845 | "dev": true,
846 | "requires": {
847 | "kind-of": "^6.0.0"
848 | }
849 | },
850 | "is-descriptor": {
851 | "version": "1.0.2",
852 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
853 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
854 | "dev": true,
855 | "requires": {
856 | "is-accessor-descriptor": "^1.0.0",
857 | "is-data-descriptor": "^1.0.0",
858 | "kind-of": "^6.0.2"
859 | }
860 | }
861 | }
862 | },
863 | "fill-range": {
864 | "version": "4.0.0",
865 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
866 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
867 | "dev": true,
868 | "requires": {
869 | "extend-shallow": "^2.0.1",
870 | "is-number": "^3.0.0",
871 | "repeat-string": "^1.6.1",
872 | "to-regex-range": "^2.1.0"
873 | },
874 | "dependencies": {
875 | "extend-shallow": {
876 | "version": "2.0.1",
877 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
878 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
879 | "dev": true,
880 | "requires": {
881 | "is-extendable": "^0.1.0"
882 | }
883 | }
884 | }
885 | },
886 | "finalhandler": {
887 | "version": "1.1.2",
888 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz",
889 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==",
890 | "requires": {
891 | "debug": "2.6.9",
892 | "encodeurl": "~1.0.2",
893 | "escape-html": "~1.0.3",
894 | "on-finished": "~2.3.0",
895 | "parseurl": "~1.3.3",
896 | "statuses": "~1.5.0",
897 | "unpipe": "~1.0.0"
898 | }
899 | },
900 | "find-up": {
901 | "version": "3.0.0",
902 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz",
903 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==",
904 | "dev": true,
905 | "requires": {
906 | "locate-path": "^3.0.0"
907 | }
908 | },
909 | "for-in": {
910 | "version": "1.0.2",
911 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz",
912 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=",
913 | "dev": true
914 | },
915 | "forwarded": {
916 | "version": "0.1.2",
917 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz",
918 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ="
919 | },
920 | "fragment-cache": {
921 | "version": "0.2.1",
922 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz",
923 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=",
924 | "dev": true,
925 | "requires": {
926 | "map-cache": "^0.2.2"
927 | }
928 | },
929 | "fresh": {
930 | "version": "0.5.2",
931 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
932 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac="
933 | },
934 | "fsevents": {
935 | "version": "1.2.9",
936 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz",
937 | "integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==",
938 | "dev": true,
939 | "optional": true,
940 | "requires": {
941 | "nan": "^2.12.1",
942 | "node-pre-gyp": "^0.12.0"
943 | },
944 | "dependencies": {
945 | "abbrev": {
946 | "version": "1.1.1",
947 | "bundled": true,
948 | "dev": true,
949 | "optional": true
950 | },
951 | "ansi-regex": {
952 | "version": "2.1.1",
953 | "bundled": true,
954 | "dev": true,
955 | "optional": true
956 | },
957 | "aproba": {
958 | "version": "1.2.0",
959 | "bundled": true,
960 | "dev": true,
961 | "optional": true
962 | },
963 | "are-we-there-yet": {
964 | "version": "1.1.5",
965 | "bundled": true,
966 | "dev": true,
967 | "optional": true,
968 | "requires": {
969 | "delegates": "^1.0.0",
970 | "readable-stream": "^2.0.6"
971 | }
972 | },
973 | "balanced-match": {
974 | "version": "1.0.0",
975 | "bundled": true,
976 | "dev": true,
977 | "optional": true
978 | },
979 | "brace-expansion": {
980 | "version": "1.1.11",
981 | "bundled": true,
982 | "dev": true,
983 | "optional": true,
984 | "requires": {
985 | "balanced-match": "^1.0.0",
986 | "concat-map": "0.0.1"
987 | }
988 | },
989 | "chownr": {
990 | "version": "1.1.1",
991 | "bundled": true,
992 | "dev": true,
993 | "optional": true
994 | },
995 | "code-point-at": {
996 | "version": "1.1.0",
997 | "bundled": true,
998 | "dev": true,
999 | "optional": true
1000 | },
1001 | "concat-map": {
1002 | "version": "0.0.1",
1003 | "bundled": true,
1004 | "dev": true,
1005 | "optional": true
1006 | },
1007 | "console-control-strings": {
1008 | "version": "1.1.0",
1009 | "bundled": true,
1010 | "dev": true,
1011 | "optional": true
1012 | },
1013 | "core-util-is": {
1014 | "version": "1.0.2",
1015 | "bundled": true,
1016 | "dev": true,
1017 | "optional": true
1018 | },
1019 | "debug": {
1020 | "version": "4.1.1",
1021 | "bundled": true,
1022 | "dev": true,
1023 | "optional": true,
1024 | "requires": {
1025 | "ms": "^2.1.1"
1026 | }
1027 | },
1028 | "deep-extend": {
1029 | "version": "0.6.0",
1030 | "bundled": true,
1031 | "dev": true,
1032 | "optional": true
1033 | },
1034 | "delegates": {
1035 | "version": "1.0.0",
1036 | "bundled": true,
1037 | "dev": true,
1038 | "optional": true
1039 | },
1040 | "detect-libc": {
1041 | "version": "1.0.3",
1042 | "bundled": true,
1043 | "dev": true,
1044 | "optional": true
1045 | },
1046 | "fs-minipass": {
1047 | "version": "1.2.5",
1048 | "bundled": true,
1049 | "dev": true,
1050 | "optional": true,
1051 | "requires": {
1052 | "minipass": "^2.2.1"
1053 | }
1054 | },
1055 | "fs.realpath": {
1056 | "version": "1.0.0",
1057 | "bundled": true,
1058 | "dev": true,
1059 | "optional": true
1060 | },
1061 | "gauge": {
1062 | "version": "2.7.4",
1063 | "bundled": true,
1064 | "dev": true,
1065 | "optional": true,
1066 | "requires": {
1067 | "aproba": "^1.0.3",
1068 | "console-control-strings": "^1.0.0",
1069 | "has-unicode": "^2.0.0",
1070 | "object-assign": "^4.1.0",
1071 | "signal-exit": "^3.0.0",
1072 | "string-width": "^1.0.1",
1073 | "strip-ansi": "^3.0.1",
1074 | "wide-align": "^1.1.0"
1075 | }
1076 | },
1077 | "glob": {
1078 | "version": "7.1.3",
1079 | "bundled": true,
1080 | "dev": true,
1081 | "optional": true,
1082 | "requires": {
1083 | "fs.realpath": "^1.0.0",
1084 | "inflight": "^1.0.4",
1085 | "inherits": "2",
1086 | "minimatch": "^3.0.4",
1087 | "once": "^1.3.0",
1088 | "path-is-absolute": "^1.0.0"
1089 | }
1090 | },
1091 | "has-unicode": {
1092 | "version": "2.0.1",
1093 | "bundled": true,
1094 | "dev": true,
1095 | "optional": true
1096 | },
1097 | "iconv-lite": {
1098 | "version": "0.4.24",
1099 | "bundled": true,
1100 | "dev": true,
1101 | "optional": true,
1102 | "requires": {
1103 | "safer-buffer": ">= 2.1.2 < 3"
1104 | }
1105 | },
1106 | "ignore-walk": {
1107 | "version": "3.0.1",
1108 | "bundled": true,
1109 | "dev": true,
1110 | "optional": true,
1111 | "requires": {
1112 | "minimatch": "^3.0.4"
1113 | }
1114 | },
1115 | "inflight": {
1116 | "version": "1.0.6",
1117 | "bundled": true,
1118 | "dev": true,
1119 | "optional": true,
1120 | "requires": {
1121 | "once": "^1.3.0",
1122 | "wrappy": "1"
1123 | }
1124 | },
1125 | "inherits": {
1126 | "version": "2.0.3",
1127 | "bundled": true,
1128 | "dev": true,
1129 | "optional": true
1130 | },
1131 | "ini": {
1132 | "version": "1.3.5",
1133 | "bundled": true,
1134 | "dev": true,
1135 | "optional": true
1136 | },
1137 | "is-fullwidth-code-point": {
1138 | "version": "1.0.0",
1139 | "bundled": true,
1140 | "dev": true,
1141 | "optional": true,
1142 | "requires": {
1143 | "number-is-nan": "^1.0.0"
1144 | }
1145 | },
1146 | "isarray": {
1147 | "version": "1.0.0",
1148 | "bundled": true,
1149 | "dev": true,
1150 | "optional": true
1151 | },
1152 | "minimatch": {
1153 | "version": "3.0.4",
1154 | "bundled": true,
1155 | "dev": true,
1156 | "optional": true,
1157 | "requires": {
1158 | "brace-expansion": "^1.1.7"
1159 | }
1160 | },
1161 | "minimist": {
1162 | "version": "0.0.8",
1163 | "bundled": true,
1164 | "dev": true,
1165 | "optional": true
1166 | },
1167 | "minipass": {
1168 | "version": "2.3.5",
1169 | "bundled": true,
1170 | "dev": true,
1171 | "optional": true,
1172 | "requires": {
1173 | "safe-buffer": "^5.1.2",
1174 | "yallist": "^3.0.0"
1175 | }
1176 | },
1177 | "minizlib": {
1178 | "version": "1.2.1",
1179 | "bundled": true,
1180 | "dev": true,
1181 | "optional": true,
1182 | "requires": {
1183 | "minipass": "^2.2.1"
1184 | }
1185 | },
1186 | "mkdirp": {
1187 | "version": "0.5.1",
1188 | "bundled": true,
1189 | "dev": true,
1190 | "optional": true,
1191 | "requires": {
1192 | "minimist": "0.0.8"
1193 | }
1194 | },
1195 | "ms": {
1196 | "version": "2.1.1",
1197 | "bundled": true,
1198 | "dev": true,
1199 | "optional": true
1200 | },
1201 | "needle": {
1202 | "version": "2.3.0",
1203 | "bundled": true,
1204 | "dev": true,
1205 | "optional": true,
1206 | "requires": {
1207 | "debug": "^4.1.0",
1208 | "iconv-lite": "^0.4.4",
1209 | "sax": "^1.2.4"
1210 | }
1211 | },
1212 | "node-pre-gyp": {
1213 | "version": "0.12.0",
1214 | "bundled": true,
1215 | "dev": true,
1216 | "optional": true,
1217 | "requires": {
1218 | "detect-libc": "^1.0.2",
1219 | "mkdirp": "^0.5.1",
1220 | "needle": "^2.2.1",
1221 | "nopt": "^4.0.1",
1222 | "npm-packlist": "^1.1.6",
1223 | "npmlog": "^4.0.2",
1224 | "rc": "^1.2.7",
1225 | "rimraf": "^2.6.1",
1226 | "semver": "^5.3.0",
1227 | "tar": "^4"
1228 | }
1229 | },
1230 | "nopt": {
1231 | "version": "4.0.1",
1232 | "bundled": true,
1233 | "dev": true,
1234 | "optional": true,
1235 | "requires": {
1236 | "abbrev": "1",
1237 | "osenv": "^0.1.4"
1238 | }
1239 | },
1240 | "npm-bundled": {
1241 | "version": "1.0.6",
1242 | "bundled": true,
1243 | "dev": true,
1244 | "optional": true
1245 | },
1246 | "npm-packlist": {
1247 | "version": "1.4.1",
1248 | "bundled": true,
1249 | "dev": true,
1250 | "optional": true,
1251 | "requires": {
1252 | "ignore-walk": "^3.0.1",
1253 | "npm-bundled": "^1.0.1"
1254 | }
1255 | },
1256 | "npmlog": {
1257 | "version": "4.1.2",
1258 | "bundled": true,
1259 | "dev": true,
1260 | "optional": true,
1261 | "requires": {
1262 | "are-we-there-yet": "~1.1.2",
1263 | "console-control-strings": "~1.1.0",
1264 | "gauge": "~2.7.3",
1265 | "set-blocking": "~2.0.0"
1266 | }
1267 | },
1268 | "number-is-nan": {
1269 | "version": "1.0.1",
1270 | "bundled": true,
1271 | "dev": true,
1272 | "optional": true
1273 | },
1274 | "object-assign": {
1275 | "version": "4.1.1",
1276 | "bundled": true,
1277 | "dev": true,
1278 | "optional": true
1279 | },
1280 | "once": {
1281 | "version": "1.4.0",
1282 | "bundled": true,
1283 | "dev": true,
1284 | "optional": true,
1285 | "requires": {
1286 | "wrappy": "1"
1287 | }
1288 | },
1289 | "os-homedir": {
1290 | "version": "1.0.2",
1291 | "bundled": true,
1292 | "dev": true,
1293 | "optional": true
1294 | },
1295 | "os-tmpdir": {
1296 | "version": "1.0.2",
1297 | "bundled": true,
1298 | "dev": true,
1299 | "optional": true
1300 | },
1301 | "osenv": {
1302 | "version": "0.1.5",
1303 | "bundled": true,
1304 | "dev": true,
1305 | "optional": true,
1306 | "requires": {
1307 | "os-homedir": "^1.0.0",
1308 | "os-tmpdir": "^1.0.0"
1309 | }
1310 | },
1311 | "path-is-absolute": {
1312 | "version": "1.0.1",
1313 | "bundled": true,
1314 | "dev": true,
1315 | "optional": true
1316 | },
1317 | "process-nextick-args": {
1318 | "version": "2.0.0",
1319 | "bundled": true,
1320 | "dev": true,
1321 | "optional": true
1322 | },
1323 | "rc": {
1324 | "version": "1.2.8",
1325 | "bundled": true,
1326 | "dev": true,
1327 | "optional": true,
1328 | "requires": {
1329 | "deep-extend": "^0.6.0",
1330 | "ini": "~1.3.0",
1331 | "minimist": "^1.2.0",
1332 | "strip-json-comments": "~2.0.1"
1333 | },
1334 | "dependencies": {
1335 | "minimist": {
1336 | "version": "1.2.0",
1337 | "bundled": true,
1338 | "dev": true,
1339 | "optional": true
1340 | }
1341 | }
1342 | },
1343 | "readable-stream": {
1344 | "version": "2.3.6",
1345 | "bundled": true,
1346 | "dev": true,
1347 | "optional": true,
1348 | "requires": {
1349 | "core-util-is": "~1.0.0",
1350 | "inherits": "~2.0.3",
1351 | "isarray": "~1.0.0",
1352 | "process-nextick-args": "~2.0.0",
1353 | "safe-buffer": "~5.1.1",
1354 | "string_decoder": "~1.1.1",
1355 | "util-deprecate": "~1.0.1"
1356 | }
1357 | },
1358 | "rimraf": {
1359 | "version": "2.6.3",
1360 | "bundled": true,
1361 | "dev": true,
1362 | "optional": true,
1363 | "requires": {
1364 | "glob": "^7.1.3"
1365 | }
1366 | },
1367 | "safe-buffer": {
1368 | "version": "5.1.2",
1369 | "bundled": true,
1370 | "dev": true,
1371 | "optional": true
1372 | },
1373 | "safer-buffer": {
1374 | "version": "2.1.2",
1375 | "bundled": true,
1376 | "dev": true,
1377 | "optional": true
1378 | },
1379 | "sax": {
1380 | "version": "1.2.4",
1381 | "bundled": true,
1382 | "dev": true,
1383 | "optional": true
1384 | },
1385 | "semver": {
1386 | "version": "5.7.0",
1387 | "bundled": true,
1388 | "dev": true,
1389 | "optional": true
1390 | },
1391 | "set-blocking": {
1392 | "version": "2.0.0",
1393 | "bundled": true,
1394 | "dev": true,
1395 | "optional": true
1396 | },
1397 | "signal-exit": {
1398 | "version": "3.0.2",
1399 | "bundled": true,
1400 | "dev": true,
1401 | "optional": true
1402 | },
1403 | "string-width": {
1404 | "version": "1.0.2",
1405 | "bundled": true,
1406 | "dev": true,
1407 | "optional": true,
1408 | "requires": {
1409 | "code-point-at": "^1.0.0",
1410 | "is-fullwidth-code-point": "^1.0.0",
1411 | "strip-ansi": "^3.0.0"
1412 | }
1413 | },
1414 | "string_decoder": {
1415 | "version": "1.1.1",
1416 | "bundled": true,
1417 | "dev": true,
1418 | "optional": true,
1419 | "requires": {
1420 | "safe-buffer": "~5.1.0"
1421 | }
1422 | },
1423 | "strip-ansi": {
1424 | "version": "3.0.1",
1425 | "bundled": true,
1426 | "dev": true,
1427 | "optional": true,
1428 | "requires": {
1429 | "ansi-regex": "^2.0.0"
1430 | }
1431 | },
1432 | "strip-json-comments": {
1433 | "version": "2.0.1",
1434 | "bundled": true,
1435 | "dev": true,
1436 | "optional": true
1437 | },
1438 | "tar": {
1439 | "version": "4.4.8",
1440 | "bundled": true,
1441 | "dev": true,
1442 | "optional": true,
1443 | "requires": {
1444 | "chownr": "^1.1.1",
1445 | "fs-minipass": "^1.2.5",
1446 | "minipass": "^2.3.4",
1447 | "minizlib": "^1.1.1",
1448 | "mkdirp": "^0.5.0",
1449 | "safe-buffer": "^5.1.2",
1450 | "yallist": "^3.0.2"
1451 | }
1452 | },
1453 | "util-deprecate": {
1454 | "version": "1.0.2",
1455 | "bundled": true,
1456 | "dev": true,
1457 | "optional": true
1458 | },
1459 | "wide-align": {
1460 | "version": "1.1.3",
1461 | "bundled": true,
1462 | "dev": true,
1463 | "optional": true,
1464 | "requires": {
1465 | "string-width": "^1.0.2 || 2"
1466 | }
1467 | },
1468 | "wrappy": {
1469 | "version": "1.0.2",
1470 | "bundled": true,
1471 | "dev": true,
1472 | "optional": true
1473 | },
1474 | "yallist": {
1475 | "version": "3.0.3",
1476 | "bundled": true,
1477 | "dev": true,
1478 | "optional": true
1479 | }
1480 | }
1481 | },
1482 | "get-caller-file": {
1483 | "version": "1.0.3",
1484 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz",
1485 | "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==",
1486 | "dev": true
1487 | },
1488 | "get-stream": {
1489 | "version": "4.1.0",
1490 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
1491 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
1492 | "dev": true,
1493 | "requires": {
1494 | "pump": "^3.0.0"
1495 | }
1496 | },
1497 | "get-value": {
1498 | "version": "2.0.6",
1499 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz",
1500 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=",
1501 | "dev": true
1502 | },
1503 | "glob-parent": {
1504 | "version": "3.1.0",
1505 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
1506 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=",
1507 | "dev": true,
1508 | "requires": {
1509 | "is-glob": "^3.1.0",
1510 | "path-dirname": "^1.0.0"
1511 | },
1512 | "dependencies": {
1513 | "is-glob": {
1514 | "version": "3.1.0",
1515 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
1516 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
1517 | "dev": true,
1518 | "requires": {
1519 | "is-extglob": "^2.1.0"
1520 | }
1521 | }
1522 | }
1523 | },
1524 | "global-dirs": {
1525 | "version": "0.1.1",
1526 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz",
1527 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=",
1528 | "dev": true,
1529 | "requires": {
1530 | "ini": "^1.3.4"
1531 | }
1532 | },
1533 | "got": {
1534 | "version": "6.7.1",
1535 | "resolved": "https://registry.npmjs.org/got/-/got-6.7.1.tgz",
1536 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=",
1537 | "dev": true,
1538 | "requires": {
1539 | "create-error-class": "^3.0.0",
1540 | "duplexer3": "^0.1.4",
1541 | "get-stream": "^3.0.0",
1542 | "is-redirect": "^1.0.0",
1543 | "is-retry-allowed": "^1.0.0",
1544 | "is-stream": "^1.0.0",
1545 | "lowercase-keys": "^1.0.0",
1546 | "safe-buffer": "^5.0.1",
1547 | "timed-out": "^4.0.0",
1548 | "unzip-response": "^2.0.1",
1549 | "url-parse-lax": "^1.0.0"
1550 | },
1551 | "dependencies": {
1552 | "get-stream": {
1553 | "version": "3.0.0",
1554 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz",
1555 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=",
1556 | "dev": true
1557 | }
1558 | }
1559 | },
1560 | "graceful-fs": {
1561 | "version": "4.1.15",
1562 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz",
1563 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==",
1564 | "dev": true
1565 | },
1566 | "has-flag": {
1567 | "version": "3.0.0",
1568 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
1569 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
1570 | "dev": true
1571 | },
1572 | "has-value": {
1573 | "version": "1.0.0",
1574 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz",
1575 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=",
1576 | "dev": true,
1577 | "requires": {
1578 | "get-value": "^2.0.6",
1579 | "has-values": "^1.0.0",
1580 | "isobject": "^3.0.0"
1581 | }
1582 | },
1583 | "has-values": {
1584 | "version": "1.0.0",
1585 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz",
1586 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=",
1587 | "dev": true,
1588 | "requires": {
1589 | "is-number": "^3.0.0",
1590 | "kind-of": "^4.0.0"
1591 | },
1592 | "dependencies": {
1593 | "kind-of": {
1594 | "version": "4.0.0",
1595 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz",
1596 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=",
1597 | "dev": true,
1598 | "requires": {
1599 | "is-buffer": "^1.1.5"
1600 | }
1601 | }
1602 | }
1603 | },
1604 | "hosted-git-info": {
1605 | "version": "2.7.1",
1606 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz",
1607 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==",
1608 | "dev": true
1609 | },
1610 | "http-errors": {
1611 | "version": "1.7.2",
1612 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz",
1613 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==",
1614 | "requires": {
1615 | "depd": "~1.1.2",
1616 | "inherits": "2.0.3",
1617 | "setprototypeof": "1.1.1",
1618 | "statuses": ">= 1.5.0 < 2",
1619 | "toidentifier": "1.0.0"
1620 | }
1621 | },
1622 | "iconv-lite": {
1623 | "version": "0.4.24",
1624 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
1625 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
1626 | "requires": {
1627 | "safer-buffer": ">= 2.1.2 < 3"
1628 | }
1629 | },
1630 | "ignore-by-default": {
1631 | "version": "1.0.1",
1632 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
1633 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=",
1634 | "dev": true
1635 | },
1636 | "import-lazy": {
1637 | "version": "2.1.0",
1638 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
1639 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=",
1640 | "dev": true
1641 | },
1642 | "imurmurhash": {
1643 | "version": "0.1.4",
1644 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
1645 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
1646 | "dev": true
1647 | },
1648 | "inherits": {
1649 | "version": "2.0.3",
1650 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
1651 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
1652 | },
1653 | "ini": {
1654 | "version": "1.3.5",
1655 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz",
1656 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==",
1657 | "dev": true
1658 | },
1659 | "invert-kv": {
1660 | "version": "2.0.0",
1661 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz",
1662 | "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==",
1663 | "dev": true
1664 | },
1665 | "ipaddr.js": {
1666 | "version": "1.9.0",
1667 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz",
1668 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA=="
1669 | },
1670 | "is-accessor-descriptor": {
1671 | "version": "0.1.6",
1672 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz",
1673 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=",
1674 | "dev": true,
1675 | "requires": {
1676 | "kind-of": "^3.0.2"
1677 | },
1678 | "dependencies": {
1679 | "kind-of": {
1680 | "version": "3.2.2",
1681 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1682 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1683 | "dev": true,
1684 | "requires": {
1685 | "is-buffer": "^1.1.5"
1686 | }
1687 | }
1688 | }
1689 | },
1690 | "is-arrayish": {
1691 | "version": "0.2.1",
1692 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
1693 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
1694 | "dev": true
1695 | },
1696 | "is-binary-path": {
1697 | "version": "1.0.1",
1698 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
1699 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
1700 | "dev": true,
1701 | "requires": {
1702 | "binary-extensions": "^1.0.0"
1703 | }
1704 | },
1705 | "is-buffer": {
1706 | "version": "1.1.6",
1707 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz",
1708 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==",
1709 | "dev": true
1710 | },
1711 | "is-ci": {
1712 | "version": "1.2.1",
1713 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz",
1714 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==",
1715 | "dev": true,
1716 | "requires": {
1717 | "ci-info": "^1.5.0"
1718 | }
1719 | },
1720 | "is-data-descriptor": {
1721 | "version": "0.1.4",
1722 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz",
1723 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=",
1724 | "dev": true,
1725 | "requires": {
1726 | "kind-of": "^3.0.2"
1727 | },
1728 | "dependencies": {
1729 | "kind-of": {
1730 | "version": "3.2.2",
1731 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1732 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1733 | "dev": true,
1734 | "requires": {
1735 | "is-buffer": "^1.1.5"
1736 | }
1737 | }
1738 | }
1739 | },
1740 | "is-descriptor": {
1741 | "version": "0.1.6",
1742 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz",
1743 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==",
1744 | "dev": true,
1745 | "requires": {
1746 | "is-accessor-descriptor": "^0.1.6",
1747 | "is-data-descriptor": "^0.1.4",
1748 | "kind-of": "^5.0.0"
1749 | },
1750 | "dependencies": {
1751 | "kind-of": {
1752 | "version": "5.1.0",
1753 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz",
1754 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==",
1755 | "dev": true
1756 | }
1757 | }
1758 | },
1759 | "is-extendable": {
1760 | "version": "0.1.1",
1761 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz",
1762 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=",
1763 | "dev": true
1764 | },
1765 | "is-extglob": {
1766 | "version": "2.1.1",
1767 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
1768 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
1769 | "dev": true
1770 | },
1771 | "is-fullwidth-code-point": {
1772 | "version": "2.0.0",
1773 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
1774 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=",
1775 | "dev": true
1776 | },
1777 | "is-glob": {
1778 | "version": "4.0.1",
1779 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
1780 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
1781 | "dev": true,
1782 | "requires": {
1783 | "is-extglob": "^2.1.1"
1784 | }
1785 | },
1786 | "is-installed-globally": {
1787 | "version": "0.1.0",
1788 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz",
1789 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=",
1790 | "dev": true,
1791 | "requires": {
1792 | "global-dirs": "^0.1.0",
1793 | "is-path-inside": "^1.0.0"
1794 | }
1795 | },
1796 | "is-npm": {
1797 | "version": "1.0.0",
1798 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz",
1799 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=",
1800 | "dev": true
1801 | },
1802 | "is-number": {
1803 | "version": "3.0.0",
1804 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
1805 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
1806 | "dev": true,
1807 | "requires": {
1808 | "kind-of": "^3.0.2"
1809 | },
1810 | "dependencies": {
1811 | "kind-of": {
1812 | "version": "3.2.2",
1813 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1814 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1815 | "dev": true,
1816 | "requires": {
1817 | "is-buffer": "^1.1.5"
1818 | }
1819 | }
1820 | }
1821 | },
1822 | "is-obj": {
1823 | "version": "1.0.1",
1824 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz",
1825 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=",
1826 | "dev": true
1827 | },
1828 | "is-path-inside": {
1829 | "version": "1.0.1",
1830 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz",
1831 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=",
1832 | "dev": true,
1833 | "requires": {
1834 | "path-is-inside": "^1.0.1"
1835 | }
1836 | },
1837 | "is-plain-object": {
1838 | "version": "2.0.4",
1839 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz",
1840 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==",
1841 | "dev": true,
1842 | "requires": {
1843 | "isobject": "^3.0.1"
1844 | }
1845 | },
1846 | "is-redirect": {
1847 | "version": "1.0.0",
1848 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz",
1849 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=",
1850 | "dev": true
1851 | },
1852 | "is-retry-allowed": {
1853 | "version": "1.1.0",
1854 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.1.0.tgz",
1855 | "integrity": "sha1-EaBgVotnM5REAz0BJaYaINVk+zQ=",
1856 | "dev": true
1857 | },
1858 | "is-stream": {
1859 | "version": "1.1.0",
1860 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz",
1861 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=",
1862 | "dev": true
1863 | },
1864 | "is-windows": {
1865 | "version": "1.0.2",
1866 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz",
1867 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==",
1868 | "dev": true
1869 | },
1870 | "isarray": {
1871 | "version": "1.0.0",
1872 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
1873 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
1874 | "dev": true
1875 | },
1876 | "isexe": {
1877 | "version": "2.0.0",
1878 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
1879 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
1880 | "dev": true
1881 | },
1882 | "isobject": {
1883 | "version": "3.0.1",
1884 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz",
1885 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=",
1886 | "dev": true
1887 | },
1888 | "json-parse-better-errors": {
1889 | "version": "1.0.2",
1890 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz",
1891 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==",
1892 | "dev": true
1893 | },
1894 | "jsonwebtoken": {
1895 | "version": "8.5.1",
1896 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz",
1897 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==",
1898 | "requires": {
1899 | "jws": "^3.2.2",
1900 | "lodash.includes": "^4.3.0",
1901 | "lodash.isboolean": "^3.0.3",
1902 | "lodash.isinteger": "^4.0.4",
1903 | "lodash.isnumber": "^3.0.3",
1904 | "lodash.isplainobject": "^4.0.6",
1905 | "lodash.isstring": "^4.0.1",
1906 | "lodash.once": "^4.0.0",
1907 | "ms": "^2.1.1",
1908 | "semver": "^5.6.0"
1909 | },
1910 | "dependencies": {
1911 | "ms": {
1912 | "version": "2.1.2",
1913 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
1914 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
1915 | }
1916 | }
1917 | },
1918 | "jwa": {
1919 | "version": "1.4.1",
1920 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz",
1921 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==",
1922 | "requires": {
1923 | "buffer-equal-constant-time": "1.0.1",
1924 | "ecdsa-sig-formatter": "1.0.11",
1925 | "safe-buffer": "^5.0.1"
1926 | }
1927 | },
1928 | "jws": {
1929 | "version": "3.2.2",
1930 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz",
1931 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==",
1932 | "requires": {
1933 | "jwa": "^1.4.1",
1934 | "safe-buffer": "^5.0.1"
1935 | }
1936 | },
1937 | "kind-of": {
1938 | "version": "6.0.2",
1939 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz",
1940 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==",
1941 | "dev": true
1942 | },
1943 | "latest-version": {
1944 | "version": "3.1.0",
1945 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz",
1946 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=",
1947 | "dev": true,
1948 | "requires": {
1949 | "package-json": "^4.0.0"
1950 | }
1951 | },
1952 | "lcid": {
1953 | "version": "2.0.0",
1954 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz",
1955 | "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==",
1956 | "dev": true,
1957 | "requires": {
1958 | "invert-kv": "^2.0.0"
1959 | }
1960 | },
1961 | "locate-path": {
1962 | "version": "3.0.0",
1963 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz",
1964 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==",
1965 | "dev": true,
1966 | "requires": {
1967 | "p-locate": "^3.0.0",
1968 | "path-exists": "^3.0.0"
1969 | }
1970 | },
1971 | "lodash": {
1972 | "version": "4.17.15",
1973 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz",
1974 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==",
1975 | "dev": true
1976 | },
1977 | "lodash.includes": {
1978 | "version": "4.3.0",
1979 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz",
1980 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8="
1981 | },
1982 | "lodash.isboolean": {
1983 | "version": "3.0.3",
1984 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz",
1985 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY="
1986 | },
1987 | "lodash.isinteger": {
1988 | "version": "4.0.4",
1989 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz",
1990 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M="
1991 | },
1992 | "lodash.isnumber": {
1993 | "version": "3.0.3",
1994 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz",
1995 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w="
1996 | },
1997 | "lodash.isplainobject": {
1998 | "version": "4.0.6",
1999 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
2000 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs="
2001 | },
2002 | "lodash.isstring": {
2003 | "version": "4.0.1",
2004 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz",
2005 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE="
2006 | },
2007 | "lodash.once": {
2008 | "version": "4.1.1",
2009 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz",
2010 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w="
2011 | },
2012 | "lowercase-keys": {
2013 | "version": "1.0.1",
2014 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
2015 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==",
2016 | "dev": true
2017 | },
2018 | "lru-cache": {
2019 | "version": "4.1.5",
2020 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz",
2021 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==",
2022 | "dev": true,
2023 | "requires": {
2024 | "pseudomap": "^1.0.2",
2025 | "yallist": "^2.1.2"
2026 | }
2027 | },
2028 | "make-dir": {
2029 | "version": "1.3.0",
2030 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz",
2031 | "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==",
2032 | "dev": true,
2033 | "requires": {
2034 | "pify": "^3.0.0"
2035 | }
2036 | },
2037 | "map-age-cleaner": {
2038 | "version": "0.1.3",
2039 | "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz",
2040 | "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==",
2041 | "dev": true,
2042 | "requires": {
2043 | "p-defer": "^1.0.0"
2044 | }
2045 | },
2046 | "map-cache": {
2047 | "version": "0.2.2",
2048 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz",
2049 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=",
2050 | "dev": true
2051 | },
2052 | "map-visit": {
2053 | "version": "1.0.0",
2054 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz",
2055 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=",
2056 | "dev": true,
2057 | "requires": {
2058 | "object-visit": "^1.0.0"
2059 | }
2060 | },
2061 | "media-typer": {
2062 | "version": "0.3.0",
2063 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
2064 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g="
2065 | },
2066 | "mem": {
2067 | "version": "4.3.0",
2068 | "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz",
2069 | "integrity": "sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w==",
2070 | "dev": true,
2071 | "requires": {
2072 | "map-age-cleaner": "^0.1.1",
2073 | "mimic-fn": "^2.0.0",
2074 | "p-is-promise": "^2.0.0"
2075 | }
2076 | },
2077 | "merge-descriptors": {
2078 | "version": "1.0.1",
2079 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
2080 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
2081 | },
2082 | "methods": {
2083 | "version": "1.1.2",
2084 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
2085 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4="
2086 | },
2087 | "micromatch": {
2088 | "version": "3.1.10",
2089 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
2090 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
2091 | "dev": true,
2092 | "requires": {
2093 | "arr-diff": "^4.0.0",
2094 | "array-unique": "^0.3.2",
2095 | "braces": "^2.3.1",
2096 | "define-property": "^2.0.2",
2097 | "extend-shallow": "^3.0.2",
2098 | "extglob": "^2.0.4",
2099 | "fragment-cache": "^0.2.1",
2100 | "kind-of": "^6.0.2",
2101 | "nanomatch": "^1.2.9",
2102 | "object.pick": "^1.3.0",
2103 | "regex-not": "^1.0.0",
2104 | "snapdragon": "^0.8.1",
2105 | "to-regex": "^3.0.2"
2106 | }
2107 | },
2108 | "mime": {
2109 | "version": "1.6.0",
2110 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
2111 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="
2112 | },
2113 | "mime-db": {
2114 | "version": "1.40.0",
2115 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz",
2116 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA=="
2117 | },
2118 | "mime-types": {
2119 | "version": "2.1.24",
2120 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz",
2121 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==",
2122 | "requires": {
2123 | "mime-db": "1.40.0"
2124 | }
2125 | },
2126 | "mimic-fn": {
2127 | "version": "2.1.0",
2128 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
2129 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
2130 | "dev": true
2131 | },
2132 | "minimatch": {
2133 | "version": "3.0.4",
2134 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
2135 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
2136 | "dev": true,
2137 | "requires": {
2138 | "brace-expansion": "^1.1.7"
2139 | }
2140 | },
2141 | "minimist": {
2142 | "version": "1.2.0",
2143 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz",
2144 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=",
2145 | "dev": true
2146 | },
2147 | "mixin-deep": {
2148 | "version": "1.3.2",
2149 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz",
2150 | "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==",
2151 | "dev": true,
2152 | "requires": {
2153 | "for-in": "^1.0.2",
2154 | "is-extendable": "^1.0.1"
2155 | },
2156 | "dependencies": {
2157 | "is-extendable": {
2158 | "version": "1.0.1",
2159 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
2160 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
2161 | "dev": true,
2162 | "requires": {
2163 | "is-plain-object": "^2.0.4"
2164 | }
2165 | }
2166 | }
2167 | },
2168 | "ms": {
2169 | "version": "2.0.0",
2170 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
2171 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
2172 | },
2173 | "nan": {
2174 | "version": "2.14.0",
2175 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz",
2176 | "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==",
2177 | "dev": true,
2178 | "optional": true
2179 | },
2180 | "nanomatch": {
2181 | "version": "1.2.13",
2182 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz",
2183 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==",
2184 | "dev": true,
2185 | "requires": {
2186 | "arr-diff": "^4.0.0",
2187 | "array-unique": "^0.3.2",
2188 | "define-property": "^2.0.2",
2189 | "extend-shallow": "^3.0.2",
2190 | "fragment-cache": "^0.2.1",
2191 | "is-windows": "^1.0.2",
2192 | "kind-of": "^6.0.2",
2193 | "object.pick": "^1.3.0",
2194 | "regex-not": "^1.0.0",
2195 | "snapdragon": "^0.8.1",
2196 | "to-regex": "^3.0.1"
2197 | }
2198 | },
2199 | "negotiator": {
2200 | "version": "0.6.2",
2201 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz",
2202 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw=="
2203 | },
2204 | "nice-try": {
2205 | "version": "1.0.5",
2206 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
2207 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==",
2208 | "dev": true
2209 | },
2210 | "nodemon": {
2211 | "version": "1.19.1",
2212 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.19.1.tgz",
2213 | "integrity": "sha512-/DXLzd/GhiaDXXbGId5BzxP1GlsqtMGM9zTmkWrgXtSqjKmGSbLicM/oAy4FR0YWm14jCHRwnR31AHS2dYFHrg==",
2214 | "dev": true,
2215 | "requires": {
2216 | "chokidar": "^2.1.5",
2217 | "debug": "^3.1.0",
2218 | "ignore-by-default": "^1.0.1",
2219 | "minimatch": "^3.0.4",
2220 | "pstree.remy": "^1.1.6",
2221 | "semver": "^5.5.0",
2222 | "supports-color": "^5.2.0",
2223 | "touch": "^3.1.0",
2224 | "undefsafe": "^2.0.2",
2225 | "update-notifier": "^2.5.0"
2226 | },
2227 | "dependencies": {
2228 | "debug": {
2229 | "version": "3.2.6",
2230 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz",
2231 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==",
2232 | "dev": true,
2233 | "requires": {
2234 | "ms": "^2.1.1"
2235 | }
2236 | },
2237 | "ms": {
2238 | "version": "2.1.2",
2239 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
2240 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
2241 | "dev": true
2242 | },
2243 | "supports-color": {
2244 | "version": "5.5.0",
2245 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
2246 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
2247 | "dev": true,
2248 | "requires": {
2249 | "has-flag": "^3.0.0"
2250 | }
2251 | }
2252 | }
2253 | },
2254 | "nopt": {
2255 | "version": "1.0.10",
2256 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
2257 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=",
2258 | "dev": true,
2259 | "requires": {
2260 | "abbrev": "1"
2261 | }
2262 | },
2263 | "normalize-package-data": {
2264 | "version": "2.5.0",
2265 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz",
2266 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==",
2267 | "dev": true,
2268 | "requires": {
2269 | "hosted-git-info": "^2.1.4",
2270 | "resolve": "^1.10.0",
2271 | "semver": "2 || 3 || 4 || 5",
2272 | "validate-npm-package-license": "^3.0.1"
2273 | }
2274 | },
2275 | "normalize-path": {
2276 | "version": "3.0.0",
2277 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
2278 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
2279 | "dev": true
2280 | },
2281 | "npm-run-path": {
2282 | "version": "2.0.2",
2283 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz",
2284 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=",
2285 | "dev": true,
2286 | "requires": {
2287 | "path-key": "^2.0.0"
2288 | }
2289 | },
2290 | "number-is-nan": {
2291 | "version": "1.0.1",
2292 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz",
2293 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=",
2294 | "dev": true
2295 | },
2296 | "object-copy": {
2297 | "version": "0.1.0",
2298 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz",
2299 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=",
2300 | "dev": true,
2301 | "requires": {
2302 | "copy-descriptor": "^0.1.0",
2303 | "define-property": "^0.2.5",
2304 | "kind-of": "^3.0.3"
2305 | },
2306 | "dependencies": {
2307 | "define-property": {
2308 | "version": "0.2.5",
2309 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
2310 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
2311 | "dev": true,
2312 | "requires": {
2313 | "is-descriptor": "^0.1.0"
2314 | }
2315 | },
2316 | "kind-of": {
2317 | "version": "3.2.2",
2318 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
2319 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
2320 | "dev": true,
2321 | "requires": {
2322 | "is-buffer": "^1.1.5"
2323 | }
2324 | }
2325 | }
2326 | },
2327 | "object-visit": {
2328 | "version": "1.0.1",
2329 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz",
2330 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=",
2331 | "dev": true,
2332 | "requires": {
2333 | "isobject": "^3.0.0"
2334 | }
2335 | },
2336 | "object.pick": {
2337 | "version": "1.3.0",
2338 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz",
2339 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=",
2340 | "dev": true,
2341 | "requires": {
2342 | "isobject": "^3.0.1"
2343 | }
2344 | },
2345 | "on-finished": {
2346 | "version": "2.3.0",
2347 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
2348 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
2349 | "requires": {
2350 | "ee-first": "1.1.1"
2351 | }
2352 | },
2353 | "once": {
2354 | "version": "1.4.0",
2355 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
2356 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
2357 | "dev": true,
2358 | "requires": {
2359 | "wrappy": "1"
2360 | }
2361 | },
2362 | "os-locale": {
2363 | "version": "3.1.0",
2364 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz",
2365 | "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==",
2366 | "dev": true,
2367 | "requires": {
2368 | "execa": "^1.0.0",
2369 | "lcid": "^2.0.0",
2370 | "mem": "^4.0.0"
2371 | }
2372 | },
2373 | "p-defer": {
2374 | "version": "1.0.0",
2375 | "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz",
2376 | "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=",
2377 | "dev": true
2378 | },
2379 | "p-finally": {
2380 | "version": "1.0.0",
2381 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
2382 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=",
2383 | "dev": true
2384 | },
2385 | "p-is-promise": {
2386 | "version": "2.1.0",
2387 | "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz",
2388 | "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==",
2389 | "dev": true
2390 | },
2391 | "p-limit": {
2392 | "version": "2.2.0",
2393 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.0.tgz",
2394 | "integrity": "sha512-pZbTJpoUsCzV48Mc9Nh51VbwO0X9cuPFE8gYwx9BTCt9SF8/b7Zljd2fVgOxhIF/HDTKgpVzs+GPhyKfjLLFRQ==",
2395 | "dev": true,
2396 | "requires": {
2397 | "p-try": "^2.0.0"
2398 | }
2399 | },
2400 | "p-locate": {
2401 | "version": "3.0.0",
2402 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz",
2403 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==",
2404 | "dev": true,
2405 | "requires": {
2406 | "p-limit": "^2.0.0"
2407 | }
2408 | },
2409 | "p-try": {
2410 | "version": "2.2.0",
2411 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
2412 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
2413 | "dev": true
2414 | },
2415 | "package-json": {
2416 | "version": "4.0.1",
2417 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz",
2418 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=",
2419 | "dev": true,
2420 | "requires": {
2421 | "got": "^6.7.1",
2422 | "registry-auth-token": "^3.0.1",
2423 | "registry-url": "^3.0.3",
2424 | "semver": "^5.1.0"
2425 | }
2426 | },
2427 | "packet-reader": {
2428 | "version": "1.0.0",
2429 | "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz",
2430 | "integrity": "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ=="
2431 | },
2432 | "parse-json": {
2433 | "version": "4.0.0",
2434 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz",
2435 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=",
2436 | "dev": true,
2437 | "requires": {
2438 | "error-ex": "^1.3.1",
2439 | "json-parse-better-errors": "^1.0.1"
2440 | }
2441 | },
2442 | "parseurl": {
2443 | "version": "1.3.3",
2444 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
2445 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ=="
2446 | },
2447 | "pascalcase": {
2448 | "version": "0.1.1",
2449 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz",
2450 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=",
2451 | "dev": true
2452 | },
2453 | "path-dirname": {
2454 | "version": "1.0.2",
2455 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz",
2456 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=",
2457 | "dev": true
2458 | },
2459 | "path-exists": {
2460 | "version": "3.0.0",
2461 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz",
2462 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=",
2463 | "dev": true
2464 | },
2465 | "path-is-absolute": {
2466 | "version": "1.0.1",
2467 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
2468 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
2469 | "dev": true
2470 | },
2471 | "path-is-inside": {
2472 | "version": "1.0.2",
2473 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz",
2474 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=",
2475 | "dev": true
2476 | },
2477 | "path-key": {
2478 | "version": "2.0.1",
2479 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
2480 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
2481 | "dev": true
2482 | },
2483 | "path-parse": {
2484 | "version": "1.0.6",
2485 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz",
2486 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==",
2487 | "dev": true
2488 | },
2489 | "path-to-regexp": {
2490 | "version": "0.1.7",
2491 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
2492 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
2493 | },
2494 | "pg": {
2495 | "version": "7.11.0",
2496 | "resolved": "https://registry.npmjs.org/pg/-/pg-7.11.0.tgz",
2497 | "integrity": "sha512-YO4V7vCmEMGoF390LJaFaohWNKaA2ayoQOEZmiHVcAUF+YsRThpf/TaKCgSvsSE7cDm37Q/Cy3Gz41xiX/XjTw==",
2498 | "requires": {
2499 | "buffer-writer": "2.0.0",
2500 | "packet-reader": "1.0.0",
2501 | "pg-connection-string": "0.1.3",
2502 | "pg-pool": "^2.0.4",
2503 | "pg-types": "~2.0.0",
2504 | "pgpass": "1.x",
2505 | "semver": "4.3.2"
2506 | },
2507 | "dependencies": {
2508 | "semver": {
2509 | "version": "4.3.2",
2510 | "resolved": "https://registry.npmjs.org/semver/-/semver-4.3.2.tgz",
2511 | "integrity": "sha1-x6BxWKgL7dBSNVt3DYLWZA+AO+c="
2512 | }
2513 | }
2514 | },
2515 | "pg-connection-string": {
2516 | "version": "0.1.3",
2517 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-0.1.3.tgz",
2518 | "integrity": "sha1-2hhHsglA5C7hSSvq9l1J2RskXfc="
2519 | },
2520 | "pg-int8": {
2521 | "version": "1.0.1",
2522 | "resolved": "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz",
2523 | "integrity": "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw=="
2524 | },
2525 | "pg-pool": {
2526 | "version": "2.0.6",
2527 | "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-2.0.6.tgz",
2528 | "integrity": "sha512-hod2zYQxM8Gt482q+qONGTYcg/qVcV32VHVPtktbBJs0us3Dj7xibISw0BAAXVMCzt8A/jhfJvpZaxUlqtqs0g=="
2529 | },
2530 | "pg-types": {
2531 | "version": "2.0.1",
2532 | "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-2.0.1.tgz",
2533 | "integrity": "sha512-b7y6QM1VF5nOeX9ukMQ0h8a9z89mojrBHXfJeSug4mhL0YpxNBm83ot2TROyoAmX/ZOX3UbwVO4EbH7i1ZZNiw==",
2534 | "requires": {
2535 | "pg-int8": "1.0.1",
2536 | "postgres-array": "~2.0.0",
2537 | "postgres-bytea": "~1.0.0",
2538 | "postgres-date": "~1.0.4",
2539 | "postgres-interval": "^1.1.0"
2540 | }
2541 | },
2542 | "pgpass": {
2543 | "version": "1.0.2",
2544 | "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.2.tgz",
2545 | "integrity": "sha1-Knu0G2BltnkH6R2hsHwYR8h3swY=",
2546 | "requires": {
2547 | "split": "^1.0.0"
2548 | }
2549 | },
2550 | "pify": {
2551 | "version": "3.0.0",
2552 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz",
2553 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=",
2554 | "dev": true
2555 | },
2556 | "posix-character-classes": {
2557 | "version": "0.1.1",
2558 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz",
2559 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=",
2560 | "dev": true
2561 | },
2562 | "postgres-array": {
2563 | "version": "2.0.0",
2564 | "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz",
2565 | "integrity": "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA=="
2566 | },
2567 | "postgres-bytea": {
2568 | "version": "1.0.0",
2569 | "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz",
2570 | "integrity": "sha1-AntTPAqokOJtFy1Hz5zOzFIazTU="
2571 | },
2572 | "postgres-date": {
2573 | "version": "1.0.4",
2574 | "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.4.tgz",
2575 | "integrity": "sha512-bESRvKVuTrjoBluEcpv2346+6kgB7UlnqWZsnbnCccTNq/pqfj1j6oBaN5+b/NrDXepYUT/HKadqv3iS9lJuVA=="
2576 | },
2577 | "postgres-interval": {
2578 | "version": "1.2.0",
2579 | "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz",
2580 | "integrity": "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==",
2581 | "requires": {
2582 | "xtend": "^4.0.0"
2583 | }
2584 | },
2585 | "prepend-http": {
2586 | "version": "1.0.4",
2587 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz",
2588 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=",
2589 | "dev": true
2590 | },
2591 | "process-nextick-args": {
2592 | "version": "2.0.0",
2593 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz",
2594 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==",
2595 | "dev": true
2596 | },
2597 | "proxy-addr": {
2598 | "version": "2.0.5",
2599 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz",
2600 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==",
2601 | "requires": {
2602 | "forwarded": "~0.1.2",
2603 | "ipaddr.js": "1.9.0"
2604 | }
2605 | },
2606 | "pseudomap": {
2607 | "version": "1.0.2",
2608 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz",
2609 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=",
2610 | "dev": true
2611 | },
2612 | "pstree.remy": {
2613 | "version": "1.1.7",
2614 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.7.tgz",
2615 | "integrity": "sha512-xsMgrUwRpuGskEzBFkH8NmTimbZ5PcPup0LA8JJkHIm2IMUbQcpo3yeLNWVrufEYjh8YwtSVh0xz6UeWc5Oh5A==",
2616 | "dev": true
2617 | },
2618 | "pump": {
2619 | "version": "3.0.0",
2620 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
2621 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
2622 | "dev": true,
2623 | "requires": {
2624 | "end-of-stream": "^1.1.0",
2625 | "once": "^1.3.1"
2626 | }
2627 | },
2628 | "qs": {
2629 | "version": "6.7.0",
2630 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz",
2631 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ=="
2632 | },
2633 | "range-parser": {
2634 | "version": "1.2.1",
2635 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
2636 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg=="
2637 | },
2638 | "raw-body": {
2639 | "version": "2.4.0",
2640 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz",
2641 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==",
2642 | "requires": {
2643 | "bytes": "3.1.0",
2644 | "http-errors": "1.7.2",
2645 | "iconv-lite": "0.4.24",
2646 | "unpipe": "1.0.0"
2647 | }
2648 | },
2649 | "rc": {
2650 | "version": "1.2.8",
2651 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
2652 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
2653 | "dev": true,
2654 | "requires": {
2655 | "deep-extend": "^0.6.0",
2656 | "ini": "~1.3.0",
2657 | "minimist": "^1.2.0",
2658 | "strip-json-comments": "~2.0.1"
2659 | }
2660 | },
2661 | "read-pkg": {
2662 | "version": "4.0.1",
2663 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-4.0.1.tgz",
2664 | "integrity": "sha1-ljYlN48+HE1IyFhytabsfV0JMjc=",
2665 | "dev": true,
2666 | "requires": {
2667 | "normalize-package-data": "^2.3.2",
2668 | "parse-json": "^4.0.0",
2669 | "pify": "^3.0.0"
2670 | }
2671 | },
2672 | "readable-stream": {
2673 | "version": "2.3.6",
2674 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz",
2675 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==",
2676 | "dev": true,
2677 | "requires": {
2678 | "core-util-is": "~1.0.0",
2679 | "inherits": "~2.0.3",
2680 | "isarray": "~1.0.0",
2681 | "process-nextick-args": "~2.0.0",
2682 | "safe-buffer": "~5.1.1",
2683 | "string_decoder": "~1.1.1",
2684 | "util-deprecate": "~1.0.1"
2685 | }
2686 | },
2687 | "readdirp": {
2688 | "version": "2.2.1",
2689 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz",
2690 | "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==",
2691 | "dev": true,
2692 | "requires": {
2693 | "graceful-fs": "^4.1.11",
2694 | "micromatch": "^3.1.10",
2695 | "readable-stream": "^2.0.2"
2696 | }
2697 | },
2698 | "regex-not": {
2699 | "version": "1.0.2",
2700 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz",
2701 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==",
2702 | "dev": true,
2703 | "requires": {
2704 | "extend-shallow": "^3.0.2",
2705 | "safe-regex": "^1.1.0"
2706 | }
2707 | },
2708 | "registry-auth-token": {
2709 | "version": "3.4.0",
2710 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.4.0.tgz",
2711 | "integrity": "sha512-4LM6Fw8eBQdwMYcES4yTnn2TqIasbXuwDx3um+QRs7S55aMKCBKBxvPXl2RiUjHwuJLTyYfxSpmfSAjQpcuP+A==",
2712 | "dev": true,
2713 | "requires": {
2714 | "rc": "^1.1.6",
2715 | "safe-buffer": "^5.0.1"
2716 | }
2717 | },
2718 | "registry-url": {
2719 | "version": "3.1.0",
2720 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz",
2721 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=",
2722 | "dev": true,
2723 | "requires": {
2724 | "rc": "^1.0.1"
2725 | }
2726 | },
2727 | "remove-trailing-separator": {
2728 | "version": "1.1.0",
2729 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
2730 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
2731 | "dev": true
2732 | },
2733 | "repeat-element": {
2734 | "version": "1.1.3",
2735 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz",
2736 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==",
2737 | "dev": true
2738 | },
2739 | "repeat-string": {
2740 | "version": "1.6.1",
2741 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz",
2742 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=",
2743 | "dev": true
2744 | },
2745 | "require-directory": {
2746 | "version": "2.1.1",
2747 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
2748 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
2749 | "dev": true
2750 | },
2751 | "require-main-filename": {
2752 | "version": "1.0.1",
2753 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz",
2754 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=",
2755 | "dev": true
2756 | },
2757 | "resolve": {
2758 | "version": "1.11.1",
2759 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.11.1.tgz",
2760 | "integrity": "sha512-vIpgF6wfuJOZI7KKKSP+HmiKggadPQAdsp5HiC1mvqnfp0gF1vdwgBWZIdrVft9pgqoMFQN+R7BSWZiBxx+BBw==",
2761 | "dev": true,
2762 | "requires": {
2763 | "path-parse": "^1.0.6"
2764 | }
2765 | },
2766 | "resolve-url": {
2767 | "version": "0.2.1",
2768 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz",
2769 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=",
2770 | "dev": true
2771 | },
2772 | "ret": {
2773 | "version": "0.1.15",
2774 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz",
2775 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==",
2776 | "dev": true
2777 | },
2778 | "rxjs": {
2779 | "version": "6.5.2",
2780 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz",
2781 | "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==",
2782 | "dev": true,
2783 | "requires": {
2784 | "tslib": "^1.9.0"
2785 | }
2786 | },
2787 | "safe-buffer": {
2788 | "version": "5.1.2",
2789 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
2790 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
2791 | },
2792 | "safe-regex": {
2793 | "version": "1.1.0",
2794 | "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz",
2795 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=",
2796 | "dev": true,
2797 | "requires": {
2798 | "ret": "~0.1.10"
2799 | }
2800 | },
2801 | "safer-buffer": {
2802 | "version": "2.1.2",
2803 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
2804 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
2805 | },
2806 | "semver": {
2807 | "version": "5.7.0",
2808 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz",
2809 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA=="
2810 | },
2811 | "semver-diff": {
2812 | "version": "2.1.0",
2813 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz",
2814 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=",
2815 | "dev": true,
2816 | "requires": {
2817 | "semver": "^5.0.3"
2818 | }
2819 | },
2820 | "send": {
2821 | "version": "0.17.1",
2822 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz",
2823 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==",
2824 | "requires": {
2825 | "debug": "2.6.9",
2826 | "depd": "~1.1.2",
2827 | "destroy": "~1.0.4",
2828 | "encodeurl": "~1.0.2",
2829 | "escape-html": "~1.0.3",
2830 | "etag": "~1.8.1",
2831 | "fresh": "0.5.2",
2832 | "http-errors": "~1.7.2",
2833 | "mime": "1.6.0",
2834 | "ms": "2.1.1",
2835 | "on-finished": "~2.3.0",
2836 | "range-parser": "~1.2.1",
2837 | "statuses": "~1.5.0"
2838 | },
2839 | "dependencies": {
2840 | "ms": {
2841 | "version": "2.1.1",
2842 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz",
2843 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg=="
2844 | }
2845 | }
2846 | },
2847 | "serve-static": {
2848 | "version": "1.14.1",
2849 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz",
2850 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==",
2851 | "requires": {
2852 | "encodeurl": "~1.0.2",
2853 | "escape-html": "~1.0.3",
2854 | "parseurl": "~1.3.3",
2855 | "send": "0.17.1"
2856 | }
2857 | },
2858 | "set-blocking": {
2859 | "version": "2.0.0",
2860 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
2861 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=",
2862 | "dev": true
2863 | },
2864 | "set-value": {
2865 | "version": "2.0.1",
2866 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz",
2867 | "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==",
2868 | "dev": true,
2869 | "requires": {
2870 | "extend-shallow": "^2.0.1",
2871 | "is-extendable": "^0.1.1",
2872 | "is-plain-object": "^2.0.3",
2873 | "split-string": "^3.0.1"
2874 | },
2875 | "dependencies": {
2876 | "extend-shallow": {
2877 | "version": "2.0.1",
2878 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
2879 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
2880 | "dev": true,
2881 | "requires": {
2882 | "is-extendable": "^0.1.0"
2883 | }
2884 | }
2885 | }
2886 | },
2887 | "setprototypeof": {
2888 | "version": "1.1.1",
2889 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz",
2890 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw=="
2891 | },
2892 | "shebang-command": {
2893 | "version": "1.2.0",
2894 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
2895 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
2896 | "dev": true,
2897 | "requires": {
2898 | "shebang-regex": "^1.0.0"
2899 | }
2900 | },
2901 | "shebang-regex": {
2902 | "version": "1.0.0",
2903 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
2904 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
2905 | "dev": true
2906 | },
2907 | "signal-exit": {
2908 | "version": "3.0.2",
2909 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz",
2910 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=",
2911 | "dev": true
2912 | },
2913 | "snapdragon": {
2914 | "version": "0.8.2",
2915 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz",
2916 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==",
2917 | "dev": true,
2918 | "requires": {
2919 | "base": "^0.11.1",
2920 | "debug": "^2.2.0",
2921 | "define-property": "^0.2.5",
2922 | "extend-shallow": "^2.0.1",
2923 | "map-cache": "^0.2.2",
2924 | "source-map": "^0.5.6",
2925 | "source-map-resolve": "^0.5.0",
2926 | "use": "^3.1.0"
2927 | },
2928 | "dependencies": {
2929 | "define-property": {
2930 | "version": "0.2.5",
2931 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
2932 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
2933 | "dev": true,
2934 | "requires": {
2935 | "is-descriptor": "^0.1.0"
2936 | }
2937 | },
2938 | "extend-shallow": {
2939 | "version": "2.0.1",
2940 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
2941 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
2942 | "dev": true,
2943 | "requires": {
2944 | "is-extendable": "^0.1.0"
2945 | }
2946 | }
2947 | }
2948 | },
2949 | "snapdragon-node": {
2950 | "version": "2.1.1",
2951 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz",
2952 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==",
2953 | "dev": true,
2954 | "requires": {
2955 | "define-property": "^1.0.0",
2956 | "isobject": "^3.0.0",
2957 | "snapdragon-util": "^3.0.1"
2958 | },
2959 | "dependencies": {
2960 | "define-property": {
2961 | "version": "1.0.0",
2962 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
2963 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
2964 | "dev": true,
2965 | "requires": {
2966 | "is-descriptor": "^1.0.0"
2967 | }
2968 | },
2969 | "is-accessor-descriptor": {
2970 | "version": "1.0.0",
2971 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
2972 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
2973 | "dev": true,
2974 | "requires": {
2975 | "kind-of": "^6.0.0"
2976 | }
2977 | },
2978 | "is-data-descriptor": {
2979 | "version": "1.0.0",
2980 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
2981 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
2982 | "dev": true,
2983 | "requires": {
2984 | "kind-of": "^6.0.0"
2985 | }
2986 | },
2987 | "is-descriptor": {
2988 | "version": "1.0.2",
2989 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
2990 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
2991 | "dev": true,
2992 | "requires": {
2993 | "is-accessor-descriptor": "^1.0.0",
2994 | "is-data-descriptor": "^1.0.0",
2995 | "kind-of": "^6.0.2"
2996 | }
2997 | }
2998 | }
2999 | },
3000 | "snapdragon-util": {
3001 | "version": "3.0.1",
3002 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz",
3003 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==",
3004 | "dev": true,
3005 | "requires": {
3006 | "kind-of": "^3.2.0"
3007 | },
3008 | "dependencies": {
3009 | "kind-of": {
3010 | "version": "3.2.2",
3011 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
3012 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
3013 | "dev": true,
3014 | "requires": {
3015 | "is-buffer": "^1.1.5"
3016 | }
3017 | }
3018 | }
3019 | },
3020 | "source-map": {
3021 | "version": "0.5.7",
3022 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
3023 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
3024 | "dev": true
3025 | },
3026 | "source-map-resolve": {
3027 | "version": "0.5.2",
3028 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz",
3029 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==",
3030 | "dev": true,
3031 | "requires": {
3032 | "atob": "^2.1.1",
3033 | "decode-uri-component": "^0.2.0",
3034 | "resolve-url": "^0.2.1",
3035 | "source-map-url": "^0.4.0",
3036 | "urix": "^0.1.0"
3037 | }
3038 | },
3039 | "source-map-url": {
3040 | "version": "0.4.0",
3041 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz",
3042 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=",
3043 | "dev": true
3044 | },
3045 | "spawn-command": {
3046 | "version": "0.0.2-1",
3047 | "resolved": "https://registry.npmjs.org/spawn-command/-/spawn-command-0.0.2-1.tgz",
3048 | "integrity": "sha1-YvXpRmmBwbeW3Fkpk34RycaSG9A=",
3049 | "dev": true
3050 | },
3051 | "spdx-correct": {
3052 | "version": "3.1.0",
3053 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz",
3054 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==",
3055 | "dev": true,
3056 | "requires": {
3057 | "spdx-expression-parse": "^3.0.0",
3058 | "spdx-license-ids": "^3.0.0"
3059 | }
3060 | },
3061 | "spdx-exceptions": {
3062 | "version": "2.2.0",
3063 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz",
3064 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==",
3065 | "dev": true
3066 | },
3067 | "spdx-expression-parse": {
3068 | "version": "3.0.0",
3069 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz",
3070 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==",
3071 | "dev": true,
3072 | "requires": {
3073 | "spdx-exceptions": "^2.1.0",
3074 | "spdx-license-ids": "^3.0.0"
3075 | }
3076 | },
3077 | "spdx-license-ids": {
3078 | "version": "3.0.4",
3079 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.4.tgz",
3080 | "integrity": "sha512-7j8LYJLeY/Yb6ACbQ7F76qy5jHkp0U6jgBfJsk97bwWlVUnUWsAgpyaCvo17h0/RQGnQ036tVDomiwoI4pDkQA==",
3081 | "dev": true
3082 | },
3083 | "split": {
3084 | "version": "1.0.1",
3085 | "resolved": "https://registry.npmjs.org/split/-/split-1.0.1.tgz",
3086 | "integrity": "sha512-mTyOoPbrivtXnwnIxZRFYRrPNtEFKlpB2fvjSnCQUiAA6qAZzqwna5envK4uk6OIeP17CsdF3rSBGYVBsU0Tkg==",
3087 | "requires": {
3088 | "through": "2"
3089 | }
3090 | },
3091 | "split-string": {
3092 | "version": "3.1.0",
3093 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz",
3094 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==",
3095 | "dev": true,
3096 | "requires": {
3097 | "extend-shallow": "^3.0.0"
3098 | }
3099 | },
3100 | "static-extend": {
3101 | "version": "0.1.2",
3102 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz",
3103 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=",
3104 | "dev": true,
3105 | "requires": {
3106 | "define-property": "^0.2.5",
3107 | "object-copy": "^0.1.0"
3108 | },
3109 | "dependencies": {
3110 | "define-property": {
3111 | "version": "0.2.5",
3112 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
3113 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
3114 | "dev": true,
3115 | "requires": {
3116 | "is-descriptor": "^0.1.0"
3117 | }
3118 | }
3119 | }
3120 | },
3121 | "statuses": {
3122 | "version": "1.5.0",
3123 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
3124 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow="
3125 | },
3126 | "string-width": {
3127 | "version": "2.1.1",
3128 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
3129 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==",
3130 | "dev": true,
3131 | "requires": {
3132 | "is-fullwidth-code-point": "^2.0.0",
3133 | "strip-ansi": "^4.0.0"
3134 | }
3135 | },
3136 | "string_decoder": {
3137 | "version": "1.1.1",
3138 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
3139 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
3140 | "dev": true,
3141 | "requires": {
3142 | "safe-buffer": "~5.1.0"
3143 | }
3144 | },
3145 | "strip-ansi": {
3146 | "version": "4.0.0",
3147 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
3148 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=",
3149 | "dev": true,
3150 | "requires": {
3151 | "ansi-regex": "^3.0.0"
3152 | }
3153 | },
3154 | "strip-eof": {
3155 | "version": "1.0.0",
3156 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz",
3157 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=",
3158 | "dev": true
3159 | },
3160 | "strip-json-comments": {
3161 | "version": "2.0.1",
3162 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
3163 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
3164 | "dev": true
3165 | },
3166 | "supports-color": {
3167 | "version": "4.5.0",
3168 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz",
3169 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=",
3170 | "dev": true,
3171 | "requires": {
3172 | "has-flag": "^2.0.0"
3173 | },
3174 | "dependencies": {
3175 | "has-flag": {
3176 | "version": "2.0.0",
3177 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz",
3178 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=",
3179 | "dev": true
3180 | }
3181 | }
3182 | },
3183 | "term-size": {
3184 | "version": "1.2.0",
3185 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz",
3186 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=",
3187 | "dev": true,
3188 | "requires": {
3189 | "execa": "^0.7.0"
3190 | },
3191 | "dependencies": {
3192 | "cross-spawn": {
3193 | "version": "5.1.0",
3194 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz",
3195 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=",
3196 | "dev": true,
3197 | "requires": {
3198 | "lru-cache": "^4.0.1",
3199 | "shebang-command": "^1.2.0",
3200 | "which": "^1.2.9"
3201 | }
3202 | },
3203 | "execa": {
3204 | "version": "0.7.0",
3205 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz",
3206 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=",
3207 | "dev": true,
3208 | "requires": {
3209 | "cross-spawn": "^5.0.1",
3210 | "get-stream": "^3.0.0",
3211 | "is-stream": "^1.1.0",
3212 | "npm-run-path": "^2.0.0",
3213 | "p-finally": "^1.0.0",
3214 | "signal-exit": "^3.0.0",
3215 | "strip-eof": "^1.0.0"
3216 | }
3217 | },
3218 | "get-stream": {
3219 | "version": "3.0.0",
3220 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz",
3221 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=",
3222 | "dev": true
3223 | }
3224 | }
3225 | },
3226 | "through": {
3227 | "version": "2.3.8",
3228 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz",
3229 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU="
3230 | },
3231 | "timed-out": {
3232 | "version": "4.0.1",
3233 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz",
3234 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=",
3235 | "dev": true
3236 | },
3237 | "to-object-path": {
3238 | "version": "0.3.0",
3239 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz",
3240 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=",
3241 | "dev": true,
3242 | "requires": {
3243 | "kind-of": "^3.0.2"
3244 | },
3245 | "dependencies": {
3246 | "kind-of": {
3247 | "version": "3.2.2",
3248 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
3249 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
3250 | "dev": true,
3251 | "requires": {
3252 | "is-buffer": "^1.1.5"
3253 | }
3254 | }
3255 | }
3256 | },
3257 | "to-regex": {
3258 | "version": "3.0.2",
3259 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz",
3260 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==",
3261 | "dev": true,
3262 | "requires": {
3263 | "define-property": "^2.0.2",
3264 | "extend-shallow": "^3.0.2",
3265 | "regex-not": "^1.0.2",
3266 | "safe-regex": "^1.1.0"
3267 | }
3268 | },
3269 | "to-regex-range": {
3270 | "version": "2.1.1",
3271 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
3272 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
3273 | "dev": true,
3274 | "requires": {
3275 | "is-number": "^3.0.0",
3276 | "repeat-string": "^1.6.1"
3277 | }
3278 | },
3279 | "toidentifier": {
3280 | "version": "1.0.0",
3281 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz",
3282 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw=="
3283 | },
3284 | "touch": {
3285 | "version": "3.1.0",
3286 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
3287 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
3288 | "dev": true,
3289 | "requires": {
3290 | "nopt": "~1.0.10"
3291 | }
3292 | },
3293 | "tree-kill": {
3294 | "version": "1.2.1",
3295 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.1.tgz",
3296 | "integrity": "sha512-4hjqbObwlh2dLyW4tcz0Ymw0ggoaVDMveUB9w8kFSQScdRLo0gxO9J7WFcUBo+W3C1TLdFIEwNOWebgZZ0RH9Q==",
3297 | "dev": true
3298 | },
3299 | "tslib": {
3300 | "version": "1.9.3",
3301 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz",
3302 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==",
3303 | "dev": true
3304 | },
3305 | "type-is": {
3306 | "version": "1.6.18",
3307 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
3308 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
3309 | "requires": {
3310 | "media-typer": "0.3.0",
3311 | "mime-types": "~2.1.24"
3312 | }
3313 | },
3314 | "undefsafe": {
3315 | "version": "2.0.2",
3316 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.2.tgz",
3317 | "integrity": "sha1-Il9rngM3Zj4Njnz9aG/Cg2zKznY=",
3318 | "dev": true,
3319 | "requires": {
3320 | "debug": "^2.2.0"
3321 | }
3322 | },
3323 | "union-value": {
3324 | "version": "1.0.1",
3325 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz",
3326 | "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==",
3327 | "dev": true,
3328 | "requires": {
3329 | "arr-union": "^3.1.0",
3330 | "get-value": "^2.0.6",
3331 | "is-extendable": "^0.1.1",
3332 | "set-value": "^2.0.1"
3333 | }
3334 | },
3335 | "unique-string": {
3336 | "version": "1.0.0",
3337 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz",
3338 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=",
3339 | "dev": true,
3340 | "requires": {
3341 | "crypto-random-string": "^1.0.0"
3342 | }
3343 | },
3344 | "unpipe": {
3345 | "version": "1.0.0",
3346 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
3347 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw="
3348 | },
3349 | "unset-value": {
3350 | "version": "1.0.0",
3351 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz",
3352 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=",
3353 | "dev": true,
3354 | "requires": {
3355 | "has-value": "^0.3.1",
3356 | "isobject": "^3.0.0"
3357 | },
3358 | "dependencies": {
3359 | "has-value": {
3360 | "version": "0.3.1",
3361 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz",
3362 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=",
3363 | "dev": true,
3364 | "requires": {
3365 | "get-value": "^2.0.3",
3366 | "has-values": "^0.1.4",
3367 | "isobject": "^2.0.0"
3368 | },
3369 | "dependencies": {
3370 | "isobject": {
3371 | "version": "2.1.0",
3372 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz",
3373 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=",
3374 | "dev": true,
3375 | "requires": {
3376 | "isarray": "1.0.0"
3377 | }
3378 | }
3379 | }
3380 | },
3381 | "has-values": {
3382 | "version": "0.1.4",
3383 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz",
3384 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=",
3385 | "dev": true
3386 | }
3387 | }
3388 | },
3389 | "unzip-response": {
3390 | "version": "2.0.1",
3391 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz",
3392 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=",
3393 | "dev": true
3394 | },
3395 | "upath": {
3396 | "version": "1.1.2",
3397 | "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.2.tgz",
3398 | "integrity": "sha512-kXpym8nmDmlCBr7nKdIx8P2jNBa+pBpIUFRnKJ4dr8htyYGJFokkr2ZvERRtUN+9SY+JqXouNgUPtv6JQva/2Q==",
3399 | "dev": true
3400 | },
3401 | "update-notifier": {
3402 | "version": "2.5.0",
3403 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.5.0.tgz",
3404 | "integrity": "sha512-gwMdhgJHGuj/+wHJJs9e6PcCszpxR1b236igrOkUofGhqJuG+amlIKwApH1IW1WWl7ovZxsX49lMBWLxSdm5Dw==",
3405 | "dev": true,
3406 | "requires": {
3407 | "boxen": "^1.2.1",
3408 | "chalk": "^2.0.1",
3409 | "configstore": "^3.0.0",
3410 | "import-lazy": "^2.1.0",
3411 | "is-ci": "^1.0.10",
3412 | "is-installed-globally": "^0.1.0",
3413 | "is-npm": "^1.0.0",
3414 | "latest-version": "^3.0.0",
3415 | "semver-diff": "^2.0.0",
3416 | "xdg-basedir": "^3.0.0"
3417 | }
3418 | },
3419 | "urix": {
3420 | "version": "0.1.0",
3421 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz",
3422 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=",
3423 | "dev": true
3424 | },
3425 | "url-parse-lax": {
3426 | "version": "1.0.0",
3427 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz",
3428 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=",
3429 | "dev": true,
3430 | "requires": {
3431 | "prepend-http": "^1.0.1"
3432 | }
3433 | },
3434 | "use": {
3435 | "version": "3.1.1",
3436 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz",
3437 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==",
3438 | "dev": true
3439 | },
3440 | "util-deprecate": {
3441 | "version": "1.0.2",
3442 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
3443 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=",
3444 | "dev": true
3445 | },
3446 | "utils-merge": {
3447 | "version": "1.0.1",
3448 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
3449 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM="
3450 | },
3451 | "validate-npm-package-license": {
3452 | "version": "3.0.4",
3453 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
3454 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
3455 | "dev": true,
3456 | "requires": {
3457 | "spdx-correct": "^3.0.0",
3458 | "spdx-expression-parse": "^3.0.0"
3459 | }
3460 | },
3461 | "vary": {
3462 | "version": "1.1.2",
3463 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
3464 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw="
3465 | },
3466 | "which": {
3467 | "version": "1.3.1",
3468 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
3469 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
3470 | "dev": true,
3471 | "requires": {
3472 | "isexe": "^2.0.0"
3473 | }
3474 | },
3475 | "which-module": {
3476 | "version": "2.0.0",
3477 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz",
3478 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=",
3479 | "dev": true
3480 | },
3481 | "widest-line": {
3482 | "version": "2.0.1",
3483 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-2.0.1.tgz",
3484 | "integrity": "sha512-Ba5m9/Fa4Xt9eb2ELXt77JxVDV8w7qQrH0zS/TWSJdLyAwQjWoOzpzj5lwVftDz6n/EOu3tNACS84v509qwnJA==",
3485 | "dev": true,
3486 | "requires": {
3487 | "string-width": "^2.1.1"
3488 | }
3489 | },
3490 | "wrap-ansi": {
3491 | "version": "2.1.0",
3492 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz",
3493 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=",
3494 | "dev": true,
3495 | "requires": {
3496 | "string-width": "^1.0.1",
3497 | "strip-ansi": "^3.0.1"
3498 | },
3499 | "dependencies": {
3500 | "ansi-regex": {
3501 | "version": "2.1.1",
3502 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
3503 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=",
3504 | "dev": true
3505 | },
3506 | "is-fullwidth-code-point": {
3507 | "version": "1.0.0",
3508 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz",
3509 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
3510 | "dev": true,
3511 | "requires": {
3512 | "number-is-nan": "^1.0.0"
3513 | }
3514 | },
3515 | "string-width": {
3516 | "version": "1.0.2",
3517 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz",
3518 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
3519 | "dev": true,
3520 | "requires": {
3521 | "code-point-at": "^1.0.0",
3522 | "is-fullwidth-code-point": "^1.0.0",
3523 | "strip-ansi": "^3.0.0"
3524 | }
3525 | },
3526 | "strip-ansi": {
3527 | "version": "3.0.1",
3528 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
3529 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
3530 | "dev": true,
3531 | "requires": {
3532 | "ansi-regex": "^2.0.0"
3533 | }
3534 | }
3535 | }
3536 | },
3537 | "wrappy": {
3538 | "version": "1.0.2",
3539 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
3540 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
3541 | "dev": true
3542 | },
3543 | "write-file-atomic": {
3544 | "version": "2.4.3",
3545 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz",
3546 | "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==",
3547 | "dev": true,
3548 | "requires": {
3549 | "graceful-fs": "^4.1.11",
3550 | "imurmurhash": "^0.1.4",
3551 | "signal-exit": "^3.0.2"
3552 | }
3553 | },
3554 | "xdg-basedir": {
3555 | "version": "3.0.0",
3556 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz",
3557 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=",
3558 | "dev": true
3559 | },
3560 | "xtend": {
3561 | "version": "4.0.1",
3562 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz",
3563 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68="
3564 | },
3565 | "y18n": {
3566 | "version": "4.0.0",
3567 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz",
3568 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==",
3569 | "dev": true
3570 | },
3571 | "yallist": {
3572 | "version": "2.1.2",
3573 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz",
3574 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=",
3575 | "dev": true
3576 | },
3577 | "yargs": {
3578 | "version": "12.0.5",
3579 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.5.tgz",
3580 | "integrity": "sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw==",
3581 | "dev": true,
3582 | "requires": {
3583 | "cliui": "^4.0.0",
3584 | "decamelize": "^1.2.0",
3585 | "find-up": "^3.0.0",
3586 | "get-caller-file": "^1.0.1",
3587 | "os-locale": "^3.0.0",
3588 | "require-directory": "^2.1.1",
3589 | "require-main-filename": "^1.0.1",
3590 | "set-blocking": "^2.0.0",
3591 | "string-width": "^2.0.0",
3592 | "which-module": "^2.0.0",
3593 | "y18n": "^3.2.1 || ^4.0.0",
3594 | "yargs-parser": "^11.1.1"
3595 | }
3596 | },
3597 | "yargs-parser": {
3598 | "version": "11.1.1",
3599 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-11.1.1.tgz",
3600 | "integrity": "sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ==",
3601 | "dev": true,
3602 | "requires": {
3603 | "camelcase": "^5.0.0",
3604 | "decamelize": "^1.2.0"
3605 | }
3606 | }
3607 | }
3608 | }
3609 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "blog",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "index.js",
6 | "scripts": {
7 | "client": "cd client && npm start",
8 | "server": "nodemon index.js",
9 | "dev": "concurrently -kill-others-onfail \"npm run client\" \"npm run server\""
10 | },
11 | "keywords": [],
12 | "author": "",
13 | "license": "ISC",
14 | "dependencies": {
15 | "bcryptjs": "^2.4.3",
16 | "body-parser": "^1.19.0",
17 | "express": "^4.17.1",
18 | "jsonwebtoken": "^8.5.1",
19 | "pg": "^7.11.0"
20 | },
21 | "devDependencies": {
22 | "concurrently": "^4.1.0",
23 | "dotenv": "^8.0.0",
24 | "nodemon": "^1.19.1"
25 | }
26 | }
27 |
--------------------------------------------------------------------------------
/screenshots/entry-example.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/screenshots/entry-example.png
--------------------------------------------------------------------------------
/screenshots/home-page.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/screenshots/home-page.png
--------------------------------------------------------------------------------
/screenshots/new-entry.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/screenshots/new-entry.png
--------------------------------------------------------------------------------
/screenshots/sign-in.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/screenshots/sign-in.png
--------------------------------------------------------------------------------
/screenshots/sign-up.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/alochaus/react-blog/3f7a7cb1d0a32a1df6b571c9d51182ae8abb00da/screenshots/sign-up.png
--------------------------------------------------------------------------------