├── api ├── .gitignore ├── vercel.json ├── package.json ├── index.js └── package-lock.json ├── client ├── public │ ├── robots.txt │ ├── favicon.ico │ ├── logo192.png │ ├── logo512.png │ ├── manifest.json │ └── index.html ├── src │ ├── setupTests.js │ ├── App.test.js │ ├── reportWebVitals.js │ ├── index.js │ ├── App.css │ ├── index.css │ ├── logo.svg │ └── App.js ├── .gitignore ├── package.json └── README.md ├── README.md ├── LICENSE └── .gitignore /api/.gitignore: -------------------------------------------------------------------------------- 1 | .vercel 2 | -------------------------------------------------------------------------------- /client/public/robots.txt: -------------------------------------------------------------------------------- 1 | # https://www.robotstxt.org/robotstxt.html 2 | User-agent: * 3 | Disallow: 4 | -------------------------------------------------------------------------------- /client/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/CodingGarden/gme-stonks/HEAD/client/public/favicon.ico -------------------------------------------------------------------------------- /client/public/logo192.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/CodingGarden/gme-stonks/HEAD/client/public/logo192.png -------------------------------------------------------------------------------- /client/public/logo512.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/CodingGarden/gme-stonks/HEAD/client/public/logo512.png -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # TODO 2 | 3 | * [x] Find a Stock API 4 | 6 | * [ ] Basic Webpage 7 | * [ ] Realtime Price 8 | * [ ] Chart with realtime updates and historical data -------------------------------------------------------------------------------- /client/src/setupTests.js: -------------------------------------------------------------------------------- 1 | // jest-dom adds custom jest matchers for asserting on DOM nodes. 2 | // allows you to do things like: 3 | // expect(element).toHaveTextContent(/react/i) 4 | // learn more: https://github.com/testing-library/jest-dom 5 | import '@testing-library/jest-dom'; 6 | -------------------------------------------------------------------------------- /client/src/App.test.js: -------------------------------------------------------------------------------- 1 | import { render, screen } from '@testing-library/react'; 2 | import App from './App'; 3 | 4 | test('renders learn react link', () => { 5 | render(); 6 | const linkElement = screen.getByText(/learn react/i); 7 | expect(linkElement).toBeInTheDocument(); 8 | }); 9 | -------------------------------------------------------------------------------- /api/vercel.json: -------------------------------------------------------------------------------- 1 | { 2 | "builds": [ 3 | { 4 | "src": "index.js", 5 | "use": "@now/node-server" 6 | } 7 | ], 8 | "routes": [ 9 | { 10 | "src": "/.*", 11 | "dest": "index.js" 12 | } 13 | ], 14 | "alias": [ 15 | "yahoo-finance-api" 16 | ] 17 | } -------------------------------------------------------------------------------- /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/src/reportWebVitals.js: -------------------------------------------------------------------------------- 1 | const reportWebVitals = onPerfEntry => { 2 | if (onPerfEntry && onPerfEntry instanceof Function) { 3 | import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => { 4 | getCLS(onPerfEntry); 5 | getFID(onPerfEntry); 6 | getFCP(onPerfEntry); 7 | getLCP(onPerfEntry); 8 | getTTFB(onPerfEntry); 9 | }); 10 | } 11 | }; 12 | 13 | export default reportWebVitals; 14 | -------------------------------------------------------------------------------- /api/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "api", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "node index.js" 8 | }, 9 | "keywords": [], 10 | "author": "CJ R. (https://w3cj.sh/)", 11 | "license": "MIT", 12 | "dependencies": { 13 | "axios": "^0.21.1", 14 | "cors": "^2.8.5", 15 | "express": "^4.17.1", 16 | "morgan": "^1.10.0" 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /client/src/index.js: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactDOM from 'react-dom'; 3 | import './index.css'; 4 | import App from './App'; 5 | import reportWebVitals from './reportWebVitals'; 6 | 7 | ReactDOM.render( 8 | 9 | 10 | , 11 | document.getElementById('root') 12 | ); 13 | 14 | // If you want to start measuring performance in your app, pass a function 15 | // to log results (for example: reportWebVitals(console.log)) 16 | // or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals 17 | reportWebVitals(); 18 | -------------------------------------------------------------------------------- /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 | "src": "logo192.png", 12 | "type": "image/png", 13 | "sizes": "192x192" 14 | }, 15 | { 16 | "src": "logo512.png", 17 | "type": "image/png", 18 | "sizes": "512x512" 19 | } 20 | ], 21 | "start_url": ".", 22 | "display": "standalone", 23 | "theme_color": "#000000", 24 | "background_color": "#ffffff" 25 | } 26 | -------------------------------------------------------------------------------- /client/src/App.css: -------------------------------------------------------------------------------- 1 | .App { 2 | text-align: center; 3 | } 4 | 5 | .App-logo { 6 | height: 40vmin; 7 | pointer-events: none; 8 | } 9 | 10 | @media (prefers-reduced-motion: no-preference) { 11 | .App-logo { 12 | animation: App-logo-spin infinite 20s linear; 13 | } 14 | } 15 | 16 | .App-header { 17 | background-color: #282c34; 18 | min-height: 100vh; 19 | display: flex; 20 | flex-direction: column; 21 | align-items: center; 22 | justify-content: center; 23 | font-size: calc(10px + 2vmin); 24 | color: white; 25 | } 26 | 27 | .App-link { 28 | color: #61dafb; 29 | } 30 | 31 | @keyframes App-logo-spin { 32 | from { 33 | transform: rotate(0deg); 34 | } 35 | to { 36 | transform: rotate(360deg); 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /client/src/index.css: -------------------------------------------------------------------------------- 1 | body { 2 | margin: 0; 3 | font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 4 | 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', 5 | sans-serif; 6 | -webkit-font-smoothing: antialiased; 7 | -moz-osx-font-smoothing: grayscale; 8 | } 9 | 10 | .ticker { 11 | font-size: 12.0vmin; 12 | text-align: center; 13 | } 14 | 15 | .price { 16 | font-size: 16.0vmin; 17 | text-align: center; 18 | } 19 | 20 | .price-time { 21 | font-size: 8.0vmin; 22 | text-align: center; 23 | } 24 | 25 | .up { 26 | color: #34a853; 27 | } 28 | 29 | .down { 30 | color: #d93025; 31 | } 32 | 33 | .warning { 34 | font-size: 2vmin; 35 | color: red; 36 | text-align: center; 37 | } -------------------------------------------------------------------------------- /client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "client", 3 | "version": "0.1.0", 4 | "private": true, 5 | "dependencies": { 6 | "@testing-library/jest-dom": "^5.11.4", 7 | "@testing-library/react": "^11.1.0", 8 | "@testing-library/user-event": "^12.1.10", 9 | "apexcharts": "^3.23.1", 10 | "react": "^17.0.1", 11 | "react-apexcharts": "^1.3.7", 12 | "react-dom": "^17.0.1", 13 | "react-scripts": "4.0.1", 14 | "web-vitals": "^0.2.4" 15 | }, 16 | "scripts": { 17 | "start": "SKIP_PREFLIGHT_CHECK=true react-scripts start", 18 | "build": "SKIP_PREFLIGHT_CHECK=true react-scripts build", 19 | "test": "react-scripts test", 20 | "eject": "react-scripts eject" 21 | }, 22 | "eslintConfig": { 23 | "extends": [ 24 | "react-app", 25 | "react-app/jest" 26 | ] 27 | }, 28 | "browserslist": { 29 | "production": [ 30 | ">0.2%", 31 | "not dead", 32 | "not op_mini all" 33 | ], 34 | "development": [ 35 | "last 1 chrome version", 36 | "last 1 firefox version", 37 | "last 1 safari version" 38 | ] 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License Copyright (c) 2021 Coding Garden 2 | 3 | Permission is hereby granted, free 4 | of charge, to any person obtaining a copy of this software and associated 5 | documentation files (the "Software"), to deal in the Software without 6 | restriction, including without limitation the rights to use, copy, modify, merge, 7 | publish, distribute, sublicense, and/or sell copies of the Software, and to 8 | permit persons to whom the Software is furnished to do so, subject to the 9 | following conditions: 10 | 11 | The above copyright notice and this permission notice 12 | (including the next paragraph) shall be included in all copies or substantial 13 | portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF 16 | ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 17 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO 18 | EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR 19 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20 | FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. -------------------------------------------------------------------------------- /api/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const morgan = require('morgan'); 3 | const axios = require('axios'); 4 | const cors = require('cors'); 5 | 6 | const app = express(); 7 | app.use(cors()); 8 | app.use(morgan('dev')); 9 | 10 | app.get('/', (req, res) => { 11 | res.json({ 12 | message: 'Stock API', 13 | }); 14 | }); 15 | 16 | app.get('/:ticker', async (req, res, next) => { 17 | try { 18 | const { data } = await axios.get(`https://query1.finance.yahoo.com/v8/finance/chart/${req.params.ticker}`); 19 | res.json(data); 20 | } catch (error) { 21 | next(error); 22 | } 23 | }); 24 | 25 | app.use((req, res, next) => { 26 | const error = new Error(`Not Found - ${req.originalUrl}`); 27 | res.status(404); 28 | next(error); 29 | }); 30 | 31 | // eslint-disable-next-line no-unused-vars 32 | app.use((error, req, res, next) => { 33 | const statusCode = res.statusCode === 200 ? 500 : res.statusCode; 34 | res.status(statusCode); 35 | res.json({ 36 | message: error.message, 37 | }); 38 | }); 39 | 40 | const port = process.env.PORT || 5000; 41 | app.listen(port, () => { 42 | console.log(`Listening at http://localhost:${port}`); 43 | }); 44 | -------------------------------------------------------------------------------- /client/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 12 | 13 | 17 | 18 | 27 | React App 28 | 29 | 30 | 31 |
32 | 42 | 43 | 44 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | lerna-debug.log* 8 | .pnpm-debug.log* 9 | 10 | # Diagnostic reports (https://nodejs.org/api/report.html) 11 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 12 | 13 | # Runtime data 14 | pids 15 | *.pid 16 | *.seed 17 | *.pid.lock 18 | 19 | # Directory for instrumented libs generated by jscoverage/JSCover 20 | lib-cov 21 | 22 | # Coverage directory used by tools like istanbul 23 | coverage 24 | *.lcov 25 | 26 | # nyc test coverage 27 | .nyc_output 28 | 29 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 30 | .grunt 31 | 32 | # Bower dependency directory (https://bower.io/) 33 | bower_components 34 | 35 | # node-waf configuration 36 | .lock-wscript 37 | 38 | # Compiled binary addons (https://nodejs.org/api/addons.html) 39 | build/Release 40 | 41 | # Dependency directories 42 | node_modules/ 43 | jspm_packages/ 44 | 45 | # Snowpack dependency directory (https://snowpack.dev/) 46 | web_modules/ 47 | 48 | # TypeScript cache 49 | *.tsbuildinfo 50 | 51 | # Optional npm cache directory 52 | .npm 53 | 54 | # Optional eslint cache 55 | .eslintcache 56 | 57 | # Microbundle cache 58 | .rpt2_cache/ 59 | .rts2_cache_cjs/ 60 | .rts2_cache_es/ 61 | .rts2_cache_umd/ 62 | 63 | # Optional REPL history 64 | .node_repl_history 65 | 66 | # Output of 'npm pack' 67 | *.tgz 68 | 69 | # Yarn Integrity file 70 | .yarn-integrity 71 | 72 | # dotenv environment variables file 73 | .env 74 | .env.test 75 | .env.production 76 | 77 | # parcel-bundler cache (https://parceljs.org/) 78 | .cache 79 | .parcel-cache 80 | 81 | # Next.js build output 82 | .next 83 | out 84 | 85 | # Nuxt.js build / generate output 86 | .nuxt 87 | dist 88 | 89 | # Gatsby files 90 | .cache/ 91 | # Comment in the public line in if your project uses Gatsby and not Next.js 92 | # https://nextjs.org/blog/next-9-1#public-directory-support 93 | # public 94 | 95 | # vuepress build output 96 | .vuepress/dist 97 | 98 | # Serverless directories 99 | .serverless/ 100 | 101 | # FuseBox cache 102 | .fusebox/ 103 | 104 | # DynamoDB Local files 105 | .dynamodb/ 106 | 107 | # TernJS port file 108 | .tern-port 109 | 110 | # Stores VSCode versions used for testing VSCode extensions 111 | .vscode-test 112 | 113 | # yarn v2 114 | .yarn/cache 115 | .yarn/unplugged 116 | .yarn/build-state.yml 117 | .yarn/install-state.gz 118 | .pnp.* 119 | -------------------------------------------------------------------------------- /client/src/logo.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /client/src/App.js: -------------------------------------------------------------------------------- 1 | import { useEffect, useState, useMemo } from 'react'; 2 | import Chart from 'react-apexcharts'; 3 | 4 | const stonksUrl = 'https://yahoo-finance-api.vercel.app/GME'; 5 | async function getStonks() { 6 | const response = await fetch(stonksUrl); 7 | return response.json(); 8 | } 9 | 10 | const directionEmojis = { 11 | up: '🚀', 12 | down: '💩', 13 | '': '', 14 | }; 15 | 16 | const chart = { 17 | options: { 18 | chart: { 19 | type: 'candlestick', 20 | height: 350 21 | }, 22 | title: { 23 | text: 'CandleStick Chart', 24 | align: 'left' 25 | }, 26 | xaxis: { 27 | type: 'datetime' 28 | }, 29 | yaxis: { 30 | tooltip: { 31 | enabled: true 32 | } 33 | } 34 | }, 35 | }; 36 | 37 | const round = (number) => { 38 | return number ? +(number.toFixed(2)) : null; 39 | }; 40 | 41 | function App() { 42 | const [series, setSeries] = useState([{ 43 | data: [] 44 | }]); 45 | const [price, setPrice] = useState(-1); 46 | const [prevPrice, setPrevPrice] = useState(-1); 47 | const [priceTime, setPriceTime] = useState(null); 48 | 49 | useEffect(() => { 50 | let timeoutId; 51 | async function getLatestPrice() { 52 | try { 53 | const data = await getStonks(); 54 | console.log(data); 55 | const gme = data.chart.result[0]; 56 | setPrevPrice(price); 57 | setPrice(gme.meta.regularMarketPrice.toFixed(2)); 58 | setPriceTime(new Date(gme.meta.regularMarketTime * 1000)); 59 | const quote = gme.indicators.quote[0]; 60 | const prices = gme.timestamp.map((timestamp, index) => ({ 61 | x: new Date(timestamp * 1000), 62 | y: [quote.open[index], quote.high[index], quote.low[index], quote.close[index]].map(round) 63 | })); 64 | setSeries([{ 65 | data: prices, 66 | }]); 67 | } catch (error) { 68 | console.log(error); 69 | } 70 | timeoutId = setTimeout(getLatestPrice, 5000 * 2); 71 | } 72 | 73 | getLatestPrice(); 74 | 75 | return () => { 76 | clearTimeout(timeoutId); 77 | }; 78 | }, []); 79 | 80 | const direction = useMemo(() => prevPrice < price ? 'up' : prevPrice > price ? 'down' : '', [prevPrice, price]); 81 | 82 | return ( 83 |
84 |
85 | FOR ENTERTAINMENT PURPOSES ONLY! 86 |
87 | DO NOT USE THIS SITE AS FINANCIAL ADVICE! 88 |
89 |
90 | GME 91 |
92 |
93 | ${price} {directionEmojis[direction]} 94 |
95 |
96 | {priceTime && priceTime.toLocaleTimeString()} 97 |
98 | 99 |
100 | ); 101 | } 102 | 103 | export default App; 104 | -------------------------------------------------------------------------------- /client/README.md: -------------------------------------------------------------------------------- 1 | # Getting Started with Create React App 2 | 3 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). 4 | 5 | ## Available Scripts 6 | 7 | In the project directory, you can run: 8 | 9 | ### `yarn start` 10 | 11 | Runs the app in the development mode.\ 12 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser. 13 | 14 | The page will reload if you make edits.\ 15 | You will also see any lint errors in the console. 16 | 17 | ### `yarn test` 18 | 19 | Launches the test runner in the interactive watch mode.\ 20 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information. 21 | 22 | ### `yarn build` 23 | 24 | Builds the app for production to the `build` folder.\ 25 | It correctly bundles React in production mode and optimizes the build for the best performance. 26 | 27 | The build is minified and the filenames include the hashes.\ 28 | Your app is ready to be deployed! 29 | 30 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information. 31 | 32 | ### `yarn eject` 33 | 34 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!** 35 | 36 | 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. 37 | 38 | 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. 39 | 40 | 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. 41 | 42 | ## Learn More 43 | 44 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started). 45 | 46 | To learn React, check out the [React documentation](https://reactjs.org/). 47 | 48 | ### Code Splitting 49 | 50 | This section has moved here: [https://facebook.github.io/create-react-app/docs/code-splitting](https://facebook.github.io/create-react-app/docs/code-splitting) 51 | 52 | ### Analyzing the Bundle Size 53 | 54 | This section has moved here: [https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size](https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size) 55 | 56 | ### Making a Progressive Web App 57 | 58 | This section has moved here: [https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app](https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app) 59 | 60 | ### Advanced Configuration 61 | 62 | This section has moved here: [https://facebook.github.io/create-react-app/docs/advanced-configuration](https://facebook.github.io/create-react-app/docs/advanced-configuration) 63 | 64 | ### Deployment 65 | 66 | This section has moved here: [https://facebook.github.io/create-react-app/docs/deployment](https://facebook.github.io/create-react-app/docs/deployment) 67 | 68 | ### `yarn build` fails to minify 69 | 70 | This section has moved here: [https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify](https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify) 71 | -------------------------------------------------------------------------------- /api/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "api", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "1.0.0", 9 | "license": "MIT", 10 | "dependencies": { 11 | "axios": "^0.21.1", 12 | "cors": "^2.8.5", 13 | "express": "^4.17.1", 14 | "morgan": "^1.10.0" 15 | } 16 | }, 17 | "node_modules/accepts": { 18 | "version": "1.3.7", 19 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 20 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 21 | "dependencies": { 22 | "mime-types": "~2.1.24", 23 | "negotiator": "0.6.2" 24 | }, 25 | "engines": { 26 | "node": ">= 0.6" 27 | } 28 | }, 29 | "node_modules/array-flatten": { 30 | "version": "1.1.1", 31 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 32 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 33 | }, 34 | "node_modules/axios": { 35 | "version": "0.21.1", 36 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.1.tgz", 37 | "integrity": "sha512-dKQiRHxGD9PPRIUNIWvZhPTPpl1rf/OxTYKsqKUDjBwYylTvV7SjSHJb9ratfyzM6wCdLCOYLzs73qpg5c4iGA==", 38 | "dependencies": { 39 | "follow-redirects": "^1.10.0" 40 | } 41 | }, 42 | "node_modules/basic-auth": { 43 | "version": "2.0.1", 44 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 45 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 46 | "dependencies": { 47 | "safe-buffer": "5.1.2" 48 | }, 49 | "engines": { 50 | "node": ">= 0.8" 51 | } 52 | }, 53 | "node_modules/body-parser": { 54 | "version": "1.19.0", 55 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 56 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 57 | "dependencies": { 58 | "bytes": "3.1.0", 59 | "content-type": "~1.0.4", 60 | "debug": "2.6.9", 61 | "depd": "~1.1.2", 62 | "http-errors": "1.7.2", 63 | "iconv-lite": "0.4.24", 64 | "on-finished": "~2.3.0", 65 | "qs": "6.7.0", 66 | "raw-body": "2.4.0", 67 | "type-is": "~1.6.17" 68 | }, 69 | "engines": { 70 | "node": ">= 0.8" 71 | } 72 | }, 73 | "node_modules/bytes": { 74 | "version": "3.1.0", 75 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 76 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 77 | "engines": { 78 | "node": ">= 0.8" 79 | } 80 | }, 81 | "node_modules/content-disposition": { 82 | "version": "0.5.3", 83 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 84 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 85 | "dependencies": { 86 | "safe-buffer": "5.1.2" 87 | }, 88 | "engines": { 89 | "node": ">= 0.6" 90 | } 91 | }, 92 | "node_modules/content-type": { 93 | "version": "1.0.4", 94 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 95 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 96 | "engines": { 97 | "node": ">= 0.6" 98 | } 99 | }, 100 | "node_modules/cookie": { 101 | "version": "0.4.0", 102 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 103 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==", 104 | "engines": { 105 | "node": ">= 0.6" 106 | } 107 | }, 108 | "node_modules/cookie-signature": { 109 | "version": "1.0.6", 110 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 111 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 112 | }, 113 | "node_modules/cors": { 114 | "version": "2.8.5", 115 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 116 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 117 | "dependencies": { 118 | "object-assign": "^4", 119 | "vary": "^1" 120 | }, 121 | "engines": { 122 | "node": ">= 0.10" 123 | } 124 | }, 125 | "node_modules/debug": { 126 | "version": "2.6.9", 127 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 128 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 129 | "dependencies": { 130 | "ms": "2.0.0" 131 | } 132 | }, 133 | "node_modules/depd": { 134 | "version": "1.1.2", 135 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 136 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 137 | "engines": { 138 | "node": ">= 0.6" 139 | } 140 | }, 141 | "node_modules/destroy": { 142 | "version": "1.0.4", 143 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 144 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 145 | }, 146 | "node_modules/ee-first": { 147 | "version": "1.1.1", 148 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 149 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 150 | }, 151 | "node_modules/encodeurl": { 152 | "version": "1.0.2", 153 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 154 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 155 | "engines": { 156 | "node": ">= 0.8" 157 | } 158 | }, 159 | "node_modules/escape-html": { 160 | "version": "1.0.3", 161 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 162 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 163 | }, 164 | "node_modules/etag": { 165 | "version": "1.8.1", 166 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 167 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 168 | "engines": { 169 | "node": ">= 0.6" 170 | } 171 | }, 172 | "node_modules/express": { 173 | "version": "4.17.1", 174 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 175 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 176 | "dependencies": { 177 | "accepts": "~1.3.7", 178 | "array-flatten": "1.1.1", 179 | "body-parser": "1.19.0", 180 | "content-disposition": "0.5.3", 181 | "content-type": "~1.0.4", 182 | "cookie": "0.4.0", 183 | "cookie-signature": "1.0.6", 184 | "debug": "2.6.9", 185 | "depd": "~1.1.2", 186 | "encodeurl": "~1.0.2", 187 | "escape-html": "~1.0.3", 188 | "etag": "~1.8.1", 189 | "finalhandler": "~1.1.2", 190 | "fresh": "0.5.2", 191 | "merge-descriptors": "1.0.1", 192 | "methods": "~1.1.2", 193 | "on-finished": "~2.3.0", 194 | "parseurl": "~1.3.3", 195 | "path-to-regexp": "0.1.7", 196 | "proxy-addr": "~2.0.5", 197 | "qs": "6.7.0", 198 | "range-parser": "~1.2.1", 199 | "safe-buffer": "5.1.2", 200 | "send": "0.17.1", 201 | "serve-static": "1.14.1", 202 | "setprototypeof": "1.1.1", 203 | "statuses": "~1.5.0", 204 | "type-is": "~1.6.18", 205 | "utils-merge": "1.0.1", 206 | "vary": "~1.1.2" 207 | }, 208 | "engines": { 209 | "node": ">= 0.10.0" 210 | } 211 | }, 212 | "node_modules/finalhandler": { 213 | "version": "1.1.2", 214 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 215 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 216 | "dependencies": { 217 | "debug": "2.6.9", 218 | "encodeurl": "~1.0.2", 219 | "escape-html": "~1.0.3", 220 | "on-finished": "~2.3.0", 221 | "parseurl": "~1.3.3", 222 | "statuses": "~1.5.0", 223 | "unpipe": "~1.0.0" 224 | }, 225 | "engines": { 226 | "node": ">= 0.8" 227 | } 228 | }, 229 | "node_modules/follow-redirects": { 230 | "version": "1.14.2", 231 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.2.tgz", 232 | "integrity": "sha512-yLR6WaE2lbF0x4K2qE2p9PEXKLDjUjnR/xmjS3wHAYxtlsI9MLLBJUZirAHKzUZDGLxje7w/cXR49WOUo4rbsA==", 233 | "funding": [ 234 | { 235 | "type": "individual", 236 | "url": "https://github.com/sponsors/RubenVerborgh" 237 | } 238 | ], 239 | "engines": { 240 | "node": ">=4.0" 241 | }, 242 | "peerDependenciesMeta": { 243 | "debug": { 244 | "optional": true 245 | } 246 | } 247 | }, 248 | "node_modules/forwarded": { 249 | "version": "0.2.0", 250 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 251 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 252 | "engines": { 253 | "node": ">= 0.6" 254 | } 255 | }, 256 | "node_modules/fresh": { 257 | "version": "0.5.2", 258 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 259 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 260 | "engines": { 261 | "node": ">= 0.6" 262 | } 263 | }, 264 | "node_modules/http-errors": { 265 | "version": "1.7.2", 266 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 267 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 268 | "dependencies": { 269 | "depd": "~1.1.2", 270 | "inherits": "2.0.3", 271 | "setprototypeof": "1.1.1", 272 | "statuses": ">= 1.5.0 < 2", 273 | "toidentifier": "1.0.0" 274 | }, 275 | "engines": { 276 | "node": ">= 0.6" 277 | } 278 | }, 279 | "node_modules/iconv-lite": { 280 | "version": "0.4.24", 281 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 282 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 283 | "dependencies": { 284 | "safer-buffer": ">= 2.1.2 < 3" 285 | }, 286 | "engines": { 287 | "node": ">=0.10.0" 288 | } 289 | }, 290 | "node_modules/inherits": { 291 | "version": "2.0.3", 292 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 293 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 294 | }, 295 | "node_modules/ipaddr.js": { 296 | "version": "1.9.1", 297 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 298 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 299 | "engines": { 300 | "node": ">= 0.10" 301 | } 302 | }, 303 | "node_modules/media-typer": { 304 | "version": "0.3.0", 305 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 306 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", 307 | "engines": { 308 | "node": ">= 0.6" 309 | } 310 | }, 311 | "node_modules/merge-descriptors": { 312 | "version": "1.0.1", 313 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 314 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 315 | }, 316 | "node_modules/methods": { 317 | "version": "1.1.2", 318 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 319 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 320 | "engines": { 321 | "node": ">= 0.6" 322 | } 323 | }, 324 | "node_modules/mime": { 325 | "version": "1.6.0", 326 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 327 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 328 | "bin": { 329 | "mime": "cli.js" 330 | }, 331 | "engines": { 332 | "node": ">=4" 333 | } 334 | }, 335 | "node_modules/mime-db": { 336 | "version": "1.49.0", 337 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.49.0.tgz", 338 | "integrity": "sha512-CIc8j9URtOVApSFCQIF+VBkX1RwXp/oMMOrqdyXSBXq5RWNEsRfyj1kiRnQgmNXmHxPoFIxOroKA3zcU9P+nAA==", 339 | "engines": { 340 | "node": ">= 0.6" 341 | } 342 | }, 343 | "node_modules/mime-types": { 344 | "version": "2.1.32", 345 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.32.tgz", 346 | "integrity": "sha512-hJGaVS4G4c9TSMYh2n6SQAGrC4RnfU+daP8G7cSCmaqNjiOoUY0VHCMS42pxnQmVF1GWwFhbHWn3RIxCqTmZ9A==", 347 | "dependencies": { 348 | "mime-db": "1.49.0" 349 | }, 350 | "engines": { 351 | "node": ">= 0.6" 352 | } 353 | }, 354 | "node_modules/morgan": { 355 | "version": "1.10.0", 356 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz", 357 | "integrity": "sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==", 358 | "dependencies": { 359 | "basic-auth": "~2.0.1", 360 | "debug": "2.6.9", 361 | "depd": "~2.0.0", 362 | "on-finished": "~2.3.0", 363 | "on-headers": "~1.0.2" 364 | }, 365 | "engines": { 366 | "node": ">= 0.8.0" 367 | } 368 | }, 369 | "node_modules/morgan/node_modules/depd": { 370 | "version": "2.0.0", 371 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 372 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 373 | "engines": { 374 | "node": ">= 0.8" 375 | } 376 | }, 377 | "node_modules/ms": { 378 | "version": "2.0.0", 379 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 380 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 381 | }, 382 | "node_modules/negotiator": { 383 | "version": "0.6.2", 384 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 385 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", 386 | "engines": { 387 | "node": ">= 0.6" 388 | } 389 | }, 390 | "node_modules/object-assign": { 391 | "version": "4.1.1", 392 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 393 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 394 | "engines": { 395 | "node": ">=0.10.0" 396 | } 397 | }, 398 | "node_modules/on-finished": { 399 | "version": "2.3.0", 400 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 401 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 402 | "dependencies": { 403 | "ee-first": "1.1.1" 404 | }, 405 | "engines": { 406 | "node": ">= 0.8" 407 | } 408 | }, 409 | "node_modules/on-headers": { 410 | "version": "1.0.2", 411 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 412 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", 413 | "engines": { 414 | "node": ">= 0.8" 415 | } 416 | }, 417 | "node_modules/parseurl": { 418 | "version": "1.3.3", 419 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 420 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 421 | "engines": { 422 | "node": ">= 0.8" 423 | } 424 | }, 425 | "node_modules/path-to-regexp": { 426 | "version": "0.1.7", 427 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 428 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 429 | }, 430 | "node_modules/proxy-addr": { 431 | "version": "2.0.7", 432 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 433 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 434 | "dependencies": { 435 | "forwarded": "0.2.0", 436 | "ipaddr.js": "1.9.1" 437 | }, 438 | "engines": { 439 | "node": ">= 0.10" 440 | } 441 | }, 442 | "node_modules/qs": { 443 | "version": "6.7.0", 444 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 445 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", 446 | "engines": { 447 | "node": ">=0.6" 448 | } 449 | }, 450 | "node_modules/range-parser": { 451 | "version": "1.2.1", 452 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 453 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 454 | "engines": { 455 | "node": ">= 0.6" 456 | } 457 | }, 458 | "node_modules/raw-body": { 459 | "version": "2.4.0", 460 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 461 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 462 | "dependencies": { 463 | "bytes": "3.1.0", 464 | "http-errors": "1.7.2", 465 | "iconv-lite": "0.4.24", 466 | "unpipe": "1.0.0" 467 | }, 468 | "engines": { 469 | "node": ">= 0.8" 470 | } 471 | }, 472 | "node_modules/safe-buffer": { 473 | "version": "5.1.2", 474 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 475 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 476 | }, 477 | "node_modules/safer-buffer": { 478 | "version": "2.1.2", 479 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 480 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 481 | }, 482 | "node_modules/send": { 483 | "version": "0.17.1", 484 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 485 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 486 | "dependencies": { 487 | "debug": "2.6.9", 488 | "depd": "~1.1.2", 489 | "destroy": "~1.0.4", 490 | "encodeurl": "~1.0.2", 491 | "escape-html": "~1.0.3", 492 | "etag": "~1.8.1", 493 | "fresh": "0.5.2", 494 | "http-errors": "~1.7.2", 495 | "mime": "1.6.0", 496 | "ms": "2.1.1", 497 | "on-finished": "~2.3.0", 498 | "range-parser": "~1.2.1", 499 | "statuses": "~1.5.0" 500 | }, 501 | "engines": { 502 | "node": ">= 0.8.0" 503 | } 504 | }, 505 | "node_modules/send/node_modules/ms": { 506 | "version": "2.1.1", 507 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 508 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 509 | }, 510 | "node_modules/serve-static": { 511 | "version": "1.14.1", 512 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 513 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 514 | "dependencies": { 515 | "encodeurl": "~1.0.2", 516 | "escape-html": "~1.0.3", 517 | "parseurl": "~1.3.3", 518 | "send": "0.17.1" 519 | }, 520 | "engines": { 521 | "node": ">= 0.8.0" 522 | } 523 | }, 524 | "node_modules/setprototypeof": { 525 | "version": "1.1.1", 526 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 527 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 528 | }, 529 | "node_modules/statuses": { 530 | "version": "1.5.0", 531 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 532 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 533 | "engines": { 534 | "node": ">= 0.6" 535 | } 536 | }, 537 | "node_modules/toidentifier": { 538 | "version": "1.0.0", 539 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 540 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 541 | "engines": { 542 | "node": ">=0.6" 543 | } 544 | }, 545 | "node_modules/type-is": { 546 | "version": "1.6.18", 547 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 548 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 549 | "dependencies": { 550 | "media-typer": "0.3.0", 551 | "mime-types": "~2.1.24" 552 | }, 553 | "engines": { 554 | "node": ">= 0.6" 555 | } 556 | }, 557 | "node_modules/unpipe": { 558 | "version": "1.0.0", 559 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 560 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 561 | "engines": { 562 | "node": ">= 0.8" 563 | } 564 | }, 565 | "node_modules/utils-merge": { 566 | "version": "1.0.1", 567 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 568 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 569 | "engines": { 570 | "node": ">= 0.4.0" 571 | } 572 | }, 573 | "node_modules/vary": { 574 | "version": "1.1.2", 575 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 576 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 577 | "engines": { 578 | "node": ">= 0.8" 579 | } 580 | } 581 | }, 582 | "dependencies": { 583 | "accepts": { 584 | "version": "1.3.7", 585 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 586 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 587 | "requires": { 588 | "mime-types": "~2.1.24", 589 | "negotiator": "0.6.2" 590 | } 591 | }, 592 | "array-flatten": { 593 | "version": "1.1.1", 594 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 595 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 596 | }, 597 | "axios": { 598 | "version": "0.21.1", 599 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.1.tgz", 600 | "integrity": "sha512-dKQiRHxGD9PPRIUNIWvZhPTPpl1rf/OxTYKsqKUDjBwYylTvV7SjSHJb9ratfyzM6wCdLCOYLzs73qpg5c4iGA==", 601 | "requires": { 602 | "follow-redirects": "^1.10.0" 603 | } 604 | }, 605 | "basic-auth": { 606 | "version": "2.0.1", 607 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 608 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 609 | "requires": { 610 | "safe-buffer": "5.1.2" 611 | } 612 | }, 613 | "body-parser": { 614 | "version": "1.19.0", 615 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 616 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 617 | "requires": { 618 | "bytes": "3.1.0", 619 | "content-type": "~1.0.4", 620 | "debug": "2.6.9", 621 | "depd": "~1.1.2", 622 | "http-errors": "1.7.2", 623 | "iconv-lite": "0.4.24", 624 | "on-finished": "~2.3.0", 625 | "qs": "6.7.0", 626 | "raw-body": "2.4.0", 627 | "type-is": "~1.6.17" 628 | } 629 | }, 630 | "bytes": { 631 | "version": "3.1.0", 632 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 633 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 634 | }, 635 | "content-disposition": { 636 | "version": "0.5.3", 637 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 638 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 639 | "requires": { 640 | "safe-buffer": "5.1.2" 641 | } 642 | }, 643 | "content-type": { 644 | "version": "1.0.4", 645 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 646 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 647 | }, 648 | "cookie": { 649 | "version": "0.4.0", 650 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 651 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 652 | }, 653 | "cookie-signature": { 654 | "version": "1.0.6", 655 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 656 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 657 | }, 658 | "cors": { 659 | "version": "2.8.5", 660 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 661 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 662 | "requires": { 663 | "object-assign": "^4", 664 | "vary": "^1" 665 | } 666 | }, 667 | "debug": { 668 | "version": "2.6.9", 669 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 670 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 671 | "requires": { 672 | "ms": "2.0.0" 673 | } 674 | }, 675 | "depd": { 676 | "version": "1.1.2", 677 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 678 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 679 | }, 680 | "destroy": { 681 | "version": "1.0.4", 682 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 683 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 684 | }, 685 | "ee-first": { 686 | "version": "1.1.1", 687 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 688 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 689 | }, 690 | "encodeurl": { 691 | "version": "1.0.2", 692 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 693 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 694 | }, 695 | "escape-html": { 696 | "version": "1.0.3", 697 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 698 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 699 | }, 700 | "etag": { 701 | "version": "1.8.1", 702 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 703 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 704 | }, 705 | "express": { 706 | "version": "4.17.1", 707 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 708 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 709 | "requires": { 710 | "accepts": "~1.3.7", 711 | "array-flatten": "1.1.1", 712 | "body-parser": "1.19.0", 713 | "content-disposition": "0.5.3", 714 | "content-type": "~1.0.4", 715 | "cookie": "0.4.0", 716 | "cookie-signature": "1.0.6", 717 | "debug": "2.6.9", 718 | "depd": "~1.1.2", 719 | "encodeurl": "~1.0.2", 720 | "escape-html": "~1.0.3", 721 | "etag": "~1.8.1", 722 | "finalhandler": "~1.1.2", 723 | "fresh": "0.5.2", 724 | "merge-descriptors": "1.0.1", 725 | "methods": "~1.1.2", 726 | "on-finished": "~2.3.0", 727 | "parseurl": "~1.3.3", 728 | "path-to-regexp": "0.1.7", 729 | "proxy-addr": "~2.0.5", 730 | "qs": "6.7.0", 731 | "range-parser": "~1.2.1", 732 | "safe-buffer": "5.1.2", 733 | "send": "0.17.1", 734 | "serve-static": "1.14.1", 735 | "setprototypeof": "1.1.1", 736 | "statuses": "~1.5.0", 737 | "type-is": "~1.6.18", 738 | "utils-merge": "1.0.1", 739 | "vary": "~1.1.2" 740 | } 741 | }, 742 | "finalhandler": { 743 | "version": "1.1.2", 744 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 745 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 746 | "requires": { 747 | "debug": "2.6.9", 748 | "encodeurl": "~1.0.2", 749 | "escape-html": "~1.0.3", 750 | "on-finished": "~2.3.0", 751 | "parseurl": "~1.3.3", 752 | "statuses": "~1.5.0", 753 | "unpipe": "~1.0.0" 754 | } 755 | }, 756 | "follow-redirects": { 757 | "version": "1.14.2", 758 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.2.tgz", 759 | "integrity": "sha512-yLR6WaE2lbF0x4K2qE2p9PEXKLDjUjnR/xmjS3wHAYxtlsI9MLLBJUZirAHKzUZDGLxje7w/cXR49WOUo4rbsA==" 760 | }, 761 | "forwarded": { 762 | "version": "0.2.0", 763 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 764 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 765 | }, 766 | "fresh": { 767 | "version": "0.5.2", 768 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 769 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 770 | }, 771 | "http-errors": { 772 | "version": "1.7.2", 773 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 774 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 775 | "requires": { 776 | "depd": "~1.1.2", 777 | "inherits": "2.0.3", 778 | "setprototypeof": "1.1.1", 779 | "statuses": ">= 1.5.0 < 2", 780 | "toidentifier": "1.0.0" 781 | } 782 | }, 783 | "iconv-lite": { 784 | "version": "0.4.24", 785 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 786 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 787 | "requires": { 788 | "safer-buffer": ">= 2.1.2 < 3" 789 | } 790 | }, 791 | "inherits": { 792 | "version": "2.0.3", 793 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 794 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 795 | }, 796 | "ipaddr.js": { 797 | "version": "1.9.1", 798 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 799 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 800 | }, 801 | "media-typer": { 802 | "version": "0.3.0", 803 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 804 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 805 | }, 806 | "merge-descriptors": { 807 | "version": "1.0.1", 808 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 809 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 810 | }, 811 | "methods": { 812 | "version": "1.1.2", 813 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 814 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 815 | }, 816 | "mime": { 817 | "version": "1.6.0", 818 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 819 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 820 | }, 821 | "mime-db": { 822 | "version": "1.49.0", 823 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.49.0.tgz", 824 | "integrity": "sha512-CIc8j9URtOVApSFCQIF+VBkX1RwXp/oMMOrqdyXSBXq5RWNEsRfyj1kiRnQgmNXmHxPoFIxOroKA3zcU9P+nAA==" 825 | }, 826 | "mime-types": { 827 | "version": "2.1.32", 828 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.32.tgz", 829 | "integrity": "sha512-hJGaVS4G4c9TSMYh2n6SQAGrC4RnfU+daP8G7cSCmaqNjiOoUY0VHCMS42pxnQmVF1GWwFhbHWn3RIxCqTmZ9A==", 830 | "requires": { 831 | "mime-db": "1.49.0" 832 | } 833 | }, 834 | "morgan": { 835 | "version": "1.10.0", 836 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz", 837 | "integrity": "sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==", 838 | "requires": { 839 | "basic-auth": "~2.0.1", 840 | "debug": "2.6.9", 841 | "depd": "~2.0.0", 842 | "on-finished": "~2.3.0", 843 | "on-headers": "~1.0.2" 844 | }, 845 | "dependencies": { 846 | "depd": { 847 | "version": "2.0.0", 848 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 849 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 850 | } 851 | } 852 | }, 853 | "ms": { 854 | "version": "2.0.0", 855 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 856 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 857 | }, 858 | "negotiator": { 859 | "version": "0.6.2", 860 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 861 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 862 | }, 863 | "object-assign": { 864 | "version": "4.1.1", 865 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 866 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 867 | }, 868 | "on-finished": { 869 | "version": "2.3.0", 870 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 871 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 872 | "requires": { 873 | "ee-first": "1.1.1" 874 | } 875 | }, 876 | "on-headers": { 877 | "version": "1.0.2", 878 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 879 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" 880 | }, 881 | "parseurl": { 882 | "version": "1.3.3", 883 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 884 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 885 | }, 886 | "path-to-regexp": { 887 | "version": "0.1.7", 888 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 889 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 890 | }, 891 | "proxy-addr": { 892 | "version": "2.0.7", 893 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 894 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 895 | "requires": { 896 | "forwarded": "0.2.0", 897 | "ipaddr.js": "1.9.1" 898 | } 899 | }, 900 | "qs": { 901 | "version": "6.7.0", 902 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 903 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 904 | }, 905 | "range-parser": { 906 | "version": "1.2.1", 907 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 908 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 909 | }, 910 | "raw-body": { 911 | "version": "2.4.0", 912 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 913 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 914 | "requires": { 915 | "bytes": "3.1.0", 916 | "http-errors": "1.7.2", 917 | "iconv-lite": "0.4.24", 918 | "unpipe": "1.0.0" 919 | } 920 | }, 921 | "safe-buffer": { 922 | "version": "5.1.2", 923 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 924 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 925 | }, 926 | "safer-buffer": { 927 | "version": "2.1.2", 928 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 929 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 930 | }, 931 | "send": { 932 | "version": "0.17.1", 933 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 934 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 935 | "requires": { 936 | "debug": "2.6.9", 937 | "depd": "~1.1.2", 938 | "destroy": "~1.0.4", 939 | "encodeurl": "~1.0.2", 940 | "escape-html": "~1.0.3", 941 | "etag": "~1.8.1", 942 | "fresh": "0.5.2", 943 | "http-errors": "~1.7.2", 944 | "mime": "1.6.0", 945 | "ms": "2.1.1", 946 | "on-finished": "~2.3.0", 947 | "range-parser": "~1.2.1", 948 | "statuses": "~1.5.0" 949 | }, 950 | "dependencies": { 951 | "ms": { 952 | "version": "2.1.1", 953 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 954 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 955 | } 956 | } 957 | }, 958 | "serve-static": { 959 | "version": "1.14.1", 960 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 961 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 962 | "requires": { 963 | "encodeurl": "~1.0.2", 964 | "escape-html": "~1.0.3", 965 | "parseurl": "~1.3.3", 966 | "send": "0.17.1" 967 | } 968 | }, 969 | "setprototypeof": { 970 | "version": "1.1.1", 971 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 972 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 973 | }, 974 | "statuses": { 975 | "version": "1.5.0", 976 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 977 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 978 | }, 979 | "toidentifier": { 980 | "version": "1.0.0", 981 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 982 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 983 | }, 984 | "type-is": { 985 | "version": "1.6.18", 986 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 987 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 988 | "requires": { 989 | "media-typer": "0.3.0", 990 | "mime-types": "~2.1.24" 991 | } 992 | }, 993 | "unpipe": { 994 | "version": "1.0.0", 995 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 996 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 997 | }, 998 | "utils-merge": { 999 | "version": "1.0.1", 1000 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1001 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1002 | }, 1003 | "vary": { 1004 | "version": "1.1.2", 1005 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1006 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1007 | } 1008 | } 1009 | } 1010 | --------------------------------------------------------------------------------