├── react-client ├── src │ ├── components │ │ ├── test.ts │ │ ├── joinRoom │ │ │ └── index.tsx │ │ └── game │ │ │ └── index.tsx │ ├── react-app-env.d.ts │ ├── setupTests.ts │ ├── App.test.tsx │ ├── reportWebVitals.ts │ ├── index.tsx │ ├── index.css │ ├── App.css │ ├── gameContext.ts │ ├── services │ │ ├── socketService │ │ │ └── index.ts │ │ └── gameService │ │ │ └── index.ts │ ├── App.tsx │ └── logo.svg ├── public │ ├── robots.txt │ ├── favicon.ico │ ├── logo192.png │ ├── logo512.png │ ├── manifest.json │ └── index.html ├── .vscode │ └── settings.json ├── .gitignore ├── tsconfig.json ├── package.json └── README.md ├── socketio-server ├── .gitignore ├── nodemon.json ├── tsconfig.json ├── src │ ├── public │ │ └── stylesheets │ │ │ └── style.css │ ├── routes │ │ └── index.ts │ ├── socket.ts │ ├── api │ │ └── controllers │ │ │ ├── mainController.ts │ │ │ ├── gameController.ts │ │ │ └── roomController.ts │ ├── app.ts │ └── server.ts ├── package.json └── yarn.lock └── README.md /react-client/src/components/test.ts: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /socketio-server/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules -------------------------------------------------------------------------------- /react-client/src/react-app-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /react-client/public/robots.txt: -------------------------------------------------------------------------------- 1 | # https://www.robotstxt.org/robotstxt.html 2 | User-agent: * 3 | Disallow: 4 | -------------------------------------------------------------------------------- /react-client/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ipenywis/react-socketio-tic-tac-toe/HEAD/react-client/public/favicon.ico -------------------------------------------------------------------------------- /react-client/public/logo192.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ipenywis/react-socketio-tic-tac-toe/HEAD/react-client/public/logo192.png -------------------------------------------------------------------------------- /react-client/public/logo512.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ipenywis/react-socketio-tic-tac-toe/HEAD/react-client/public/logo512.png -------------------------------------------------------------------------------- /socketio-server/nodemon.json: -------------------------------------------------------------------------------- 1 | { 2 | "watch": ["src"], 3 | "ext": "ts,json", 4 | "ignore": ["src/**/*.spec.ts"], 5 | "exec": "ts-node ./src/server" 6 | } 7 | -------------------------------------------------------------------------------- /socketio-server/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "noImplicitAny": false, 4 | "experimentalDecorators": true, 5 | "emitDecoratorMetadata": true 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /socketio-server/src/public/stylesheets/style.css: -------------------------------------------------------------------------------- 1 | body { 2 | padding: 50px; 3 | font: 14px "Lucida Grande", Helvetica, Arial, sans-serif; 4 | } 5 | 6 | a { 7 | color: #00B7FF; 8 | } 9 | -------------------------------------------------------------------------------- /socketio-server/src/routes/index.ts: -------------------------------------------------------------------------------- 1 | import * as express from "express"; 2 | 3 | const router = express.Router(); 4 | 5 | /* GET home page. */ 6 | router.get("/", function (req, res, next) { 7 | res.send("Hello Boy!!"); 8 | }); 9 | 10 | module.exports = router; 11 | -------------------------------------------------------------------------------- /react-client/src/setupTests.ts: -------------------------------------------------------------------------------- 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 | -------------------------------------------------------------------------------- /react-client/.vscode/settings.json: -------------------------------------------------------------------------------- 1 | { 2 | "editor.tokenColorCustomizations": { 3 | "tokenColors": [ 4 | { 5 | "name": "[Constant] — The main constants color", 6 | "scope": "constant", 7 | "settings": { 8 | "foreground": "#fff" 9 | } 10 | } 11 | ] 12 | } 13 | } 14 | -------------------------------------------------------------------------------- /react-client/src/App.test.tsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import { render, screen } from '@testing-library/react'; 3 | import App from './App'; 4 | 5 | test('renders learn react link', () => { 6 | render(); 7 | const linkElement = screen.getByText(/learn react/i); 8 | expect(linkElement).toBeInTheDocument(); 9 | }); 10 | -------------------------------------------------------------------------------- /react-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 | -------------------------------------------------------------------------------- /socketio-server/src/socket.ts: -------------------------------------------------------------------------------- 1 | import { useSocketServer } from "socket-controllers"; 2 | import { Server } from "socket.io"; 3 | 4 | export default (httpServer) => { 5 | const io = new Server(httpServer, { 6 | cors: { 7 | origin: "*", 8 | }, 9 | }); 10 | 11 | // io.on("connection", (socket) => { 12 | 13 | // }); 14 | 15 | useSocketServer(io, { controllers: [__dirname + "/api/controllers/*.ts"] }); 16 | 17 | return io; 18 | }; 19 | -------------------------------------------------------------------------------- /react-client/src/reportWebVitals.ts: -------------------------------------------------------------------------------- 1 | import { ReportHandler } from 'web-vitals'; 2 | 3 | const reportWebVitals = (onPerfEntry?: ReportHandler) => { 4 | if (onPerfEntry && onPerfEntry instanceof Function) { 5 | import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => { 6 | getCLS(onPerfEntry); 7 | getFID(onPerfEntry); 8 | getFCP(onPerfEntry); 9 | getLCP(onPerfEntry); 10 | getTTFB(onPerfEntry); 11 | }); 12 | } 13 | }; 14 | 15 | export default reportWebVitals; 16 | -------------------------------------------------------------------------------- /react-client/src/index.tsx: -------------------------------------------------------------------------------- 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 | -------------------------------------------------------------------------------- /socketio-server/src/api/controllers/mainController.ts: -------------------------------------------------------------------------------- 1 | import { 2 | ConnectedSocket, 3 | OnConnect, 4 | SocketController, 5 | SocketIO, 6 | } from "socket-controllers"; 7 | import { Socket, Server } from "socket.io"; 8 | 9 | @SocketController() 10 | export class MainController { 11 | @OnConnect() 12 | public onConnection( 13 | @ConnectedSocket() socket: Socket, 14 | @SocketIO() io: Server 15 | ) { 16 | console.log("New Socket connected: ", socket.id); 17 | 18 | socket.on("custom_event", (data: any) => { 19 | console.log("Data: ", data); 20 | }); 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /react-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 | -------------------------------------------------------------------------------- /react-client/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es5", 4 | "lib": [ 5 | "dom", 6 | "dom.iterable", 7 | "esnext" 8 | ], 9 | "allowJs": true, 10 | "skipLibCheck": true, 11 | "esModuleInterop": true, 12 | "allowSyntheticDefaultImports": true, 13 | "strict": true, 14 | "forceConsistentCasingInFileNames": true, 15 | "noFallthroughCasesInSwitch": true, 16 | "module": "esnext", 17 | "moduleResolution": "node", 18 | "resolveJsonModule": true, 19 | "isolatedModules": true, 20 | "noEmit": true, 21 | "jsx": "react-jsx" 22 | }, 23 | "include": [ 24 | "src" 25 | ] 26 | } 27 | -------------------------------------------------------------------------------- /react-client/src/index.css: -------------------------------------------------------------------------------- 1 | @import url("https://fonts.googleapis.com/css2?family=Zen+Tokyo+Zoo&display=swap"); 2 | 3 | * { 4 | box-sizing: border-box; 5 | } 6 | 7 | html, 8 | body, 9 | #root { 10 | width: 100%; 11 | height: 100%; 12 | } 13 | 14 | body { 15 | margin: 0; 16 | font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", 17 | "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", 18 | sans-serif; 19 | -webkit-font-smoothing: antialiased; 20 | -moz-osx-font-smoothing: grayscale; 21 | } 22 | 23 | code { 24 | font-family: source-code-pro, Menlo, Monaco, Consolas, "Courier New", 25 | monospace; 26 | } 27 | -------------------------------------------------------------------------------- /socketio-server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "socketio-server", 3 | "version": "0.0.0", 4 | "private": true, 5 | "license": "MIT", 6 | "scripts": { 7 | "start": "nodemon" 8 | }, 9 | "dependencies": { 10 | "cookie-parser": "~1.4.4", 11 | "cors": "^2.8.5", 12 | "debug": "~2.6.9", 13 | "express": "~4.16.1", 14 | "glob": "^7.1.7", 15 | "http-errors": "~1.6.3", 16 | "jade": "~1.11.0", 17 | "morgan": "~1.9.1", 18 | "reflect-metadata": "^0.1.13", 19 | "socket-controllers": "^0.0.5", 20 | "socket.io": "^4.1.2" 21 | }, 22 | "devDependencies": { 23 | "@types/node": "^16.0.0", 24 | "nodemon": "^2.0.9", 25 | "ts-node": "^10.0.0", 26 | "typescript": "^4.3.5" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |
2 | 3 | # Tic Tac Toe Online Multiplayer Game 4 | 5 | 6 | 7 |
8 | 9 | ## Youtube Video 10 | https://youtu.be/aA_SdbGD64E 11 | 12 | ### What we will cover? 13 | - Socket.io for absolute beginners 👍 14 | - Socket.io Rooms 15 | - Socket.io Class Controllers with Decorators 16 | - Socket.io with typescript 17 | - React client with socket.io server 18 | - Full fledged Tic Tac Toe game from scratch 🤓 19 | 20 | 21 | ### How to run? 22 | You can use the README file inside the projects to run it locally. 23 | 24 | 25 | Made with ❤️ by [@Ipenywis](https://twitter.com/ipenywis) Aka [CoderOne](https://youtube.com/c/coderone) -------------------------------------------------------------------------------- /react-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 | -------------------------------------------------------------------------------- /react-client/src/gameContext.ts: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export interface IGameContextProps { 4 | isInRoom: boolean; 5 | setInRoom: (inRoom: boolean) => void; 6 | playerSymbol: "x" | "o"; 7 | setPlayerSymbol: (symbol: "x" | "o") => void; 8 | isPlayerTurn: boolean; 9 | setPlayerTurn: (turn: boolean) => void; 10 | isGameStarted: boolean; 11 | setGameStarted: (started: boolean) => void; 12 | } 13 | 14 | const defaultState: IGameContextProps = { 15 | isInRoom: false, 16 | setInRoom: () => {}, 17 | playerSymbol: "x", 18 | setPlayerSymbol: () => {}, 19 | isPlayerTurn: false, 20 | setPlayerTurn: () => {}, 21 | isGameStarted: false, 22 | setGameStarted: () => {}, 23 | }; 24 | 25 | export default React.createContext(defaultState); 26 | -------------------------------------------------------------------------------- /react-client/src/services/socketService/index.ts: -------------------------------------------------------------------------------- 1 | import { io, Socket } from "socket.io-client"; 2 | import { DefaultEventsMap } from '@socket.io/component-emitter'; 3 | 4 | class SocketService { 5 | public socket: Socket | null = null; 6 | 7 | public connect( 8 | url: string 9 | ): Promise> { 10 | return new Promise((rs, rj) => { 11 | this.socket = io(url); 12 | 13 | if (!this.socket) return rj(); 14 | 15 | this.socket.on("connect", () => { 16 | rs(this.socket as Socket); 17 | }); 18 | 19 | this.socket.on("connect_error", (err) => { 20 | console.log("Connection error: ", err); 21 | rj(err); 22 | }); 23 | }); 24 | } 25 | } 26 | 27 | export default new SocketService(); 28 | -------------------------------------------------------------------------------- /socketio-server/src/api/controllers/gameController.ts: -------------------------------------------------------------------------------- 1 | import { 2 | ConnectedSocket, 3 | MessageBody, 4 | OnMessage, 5 | SocketController, 6 | SocketIO, 7 | } from "socket-controllers"; 8 | import { Server, Socket } from "socket.io"; 9 | 10 | @SocketController() 11 | export class GameController { 12 | private getSocketGameRoom(socket: Socket): string { 13 | const socketRooms = Array.from(socket.rooms.values()).filter( 14 | (r) => r !== socket.id 15 | ); 16 | const gameRoom = socketRooms && socketRooms[0]; 17 | 18 | return gameRoom; 19 | } 20 | 21 | @OnMessage("update_game") 22 | public async updateGame( 23 | @SocketIO() io: Server, 24 | @ConnectedSocket() socket: Socket, 25 | @MessageBody() message: any 26 | ) { 27 | const gameRoom = this.getSocketGameRoom(socket); 28 | socket.to(gameRoom).emit("on_game_update", message); 29 | } 30 | 31 | @OnMessage("game_win") 32 | public async gameWin( 33 | @SocketIO() io: Server, 34 | @ConnectedSocket() socket: Socket, 35 | @MessageBody() message: any 36 | ) { 37 | const gameRoom = this.getSocketGameRoom(socket); 38 | socket.to(gameRoom).emit("on_game_win", message); 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /socketio-server/src/app.ts: -------------------------------------------------------------------------------- 1 | var createError = require("http-errors"); 2 | var express = require("express"); 3 | var path = require("path"); 4 | var cookieParser = require("cookie-parser"); 5 | var logger = require("morgan"); 6 | import * as cors from "cors"; 7 | import "reflect-metadata"; 8 | 9 | var indexRouter = require("./routes/index"); 10 | 11 | var app = express(); 12 | 13 | // view engine setup 14 | // app.set('views', path.join(__dirname, 'views')); 15 | // app.set('view engine', 'jade'); 16 | 17 | app.use(logger("dev")); 18 | app.use(express.json()); 19 | app.use(express.urlencoded({ extended: false })); 20 | app.use(cookieParser()); 21 | app.use(express.static(path.join(__dirname, "public"))); 22 | app.use(cors()); 23 | 24 | app.use("/", indexRouter); 25 | 26 | // catch 404 and forward to error handler 27 | app.use(function (req, res, next) { 28 | next(createError(404)); 29 | }); 30 | 31 | // error handler 32 | app.use(function (err, req, res, next) { 33 | // set locals, only providing error in development 34 | res.locals.message = err.message; 35 | res.locals.error = req.app.get("env") === "development" ? err : {}; 36 | 37 | // render the error page 38 | res.status(err.status || 500); 39 | res.render("error"); 40 | }); 41 | 42 | export default app; 43 | -------------------------------------------------------------------------------- /react-client/src/services/gameService/index.ts: -------------------------------------------------------------------------------- 1 | import { Socket } from "socket.io-client"; 2 | import { IPlayMatrix, IStartGame } from "../../components/game"; 3 | 4 | class GameService { 5 | public async joinGameRoom(socket: Socket, roomId: string): Promise { 6 | return new Promise((rs, rj) => { 7 | socket.emit("join_game", { roomId }); 8 | socket.on("room_joined", () => rs(true)); 9 | socket.on("room_join_error", ({ error }) => rj(error)); 10 | }); 11 | } 12 | 13 | public async updateGame(socket: Socket, gameMatrix: IPlayMatrix) { 14 | socket.emit("update_game", { matrix: gameMatrix }); 15 | } 16 | 17 | public async onGameUpdate( 18 | socket: Socket, 19 | listiner: (matrix: IPlayMatrix) => void 20 | ) { 21 | socket.on("on_game_update", ({ matrix }) => listiner(matrix)); 22 | } 23 | 24 | public async onStartGame( 25 | socket: Socket, 26 | listiner: (options: IStartGame) => void 27 | ) { 28 | socket.on("start_game", listiner); 29 | } 30 | 31 | public async gameWin(socket: Socket, message: string) { 32 | socket.emit("game_win", { message }); 33 | } 34 | 35 | public async onGameWin(socket: Socket, listiner: (message: string) => void) { 36 | socket.on("on_game_win", ({ message }) => listiner(message)); 37 | } 38 | } 39 | 40 | export default new GameService(); 41 | -------------------------------------------------------------------------------- /react-client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-client", 3 | "version": "0.1.0", 4 | "private": true, 5 | "license": "MIT", 6 | "dependencies": { 7 | "@testing-library/jest-dom": "^5.11.4", 8 | "@testing-library/react": "^11.1.0", 9 | "@testing-library/user-event": "^12.1.10", 10 | "@types/jest": "^26.0.15", 11 | "@types/node": "^12.0.0", 12 | "@types/react": "^17.0.0", 13 | "@types/react-dom": "^17.0.0", 14 | "react": "^17.0.2", 15 | "react-dom": "^17.0.2", 16 | "react-scripts": "4.0.3", 17 | "socket.io-client": "^4.1.2", 18 | "styled-components": "^5.3.0", 19 | "typescript": "^4.1.2", 20 | "web-vitals": "^1.0.1" 21 | }, 22 | "scripts": { 23 | "start": "react-scripts start", 24 | "build": "react-scripts build", 25 | "test": "react-scripts test", 26 | "eject": "react-scripts eject" 27 | }, 28 | "eslintConfig": { 29 | "extends": [ 30 | "react-app", 31 | "react-app/jest" 32 | ] 33 | }, 34 | "browserslist": { 35 | "production": [ 36 | ">0.2%", 37 | "not dead", 38 | "not op_mini all" 39 | ], 40 | "development": [ 41 | "last 1 chrome version", 42 | "last 1 firefox version", 43 | "last 1 safari version" 44 | ] 45 | }, 46 | "devDependencies": { 47 | "@types/styled-components": "^5.1.11" 48 | } 49 | } 50 | -------------------------------------------------------------------------------- /socketio-server/src/api/controllers/roomController.ts: -------------------------------------------------------------------------------- 1 | import { 2 | ConnectedSocket, 3 | MessageBody, 4 | OnMessage, 5 | SocketController, 6 | SocketIO, 7 | } from "socket-controllers"; 8 | import { Server, Socket } from "socket.io"; 9 | 10 | @SocketController() 11 | export class RoomController { 12 | @OnMessage("join_game") 13 | public async joinGame( 14 | @SocketIO() io: Server, 15 | @ConnectedSocket() socket: Socket, 16 | @MessageBody() message: any 17 | ) { 18 | console.log("New User joining room: ", message); 19 | 20 | const connectedSockets = io.sockets.adapter.rooms.get(message.roomId); 21 | const socketRooms = Array.from(socket.rooms.values()).filter( 22 | (r) => r !== socket.id 23 | ); 24 | 25 | if ( 26 | socketRooms.length > 0 || 27 | (connectedSockets && connectedSockets.size === 2) 28 | ) { 29 | socket.emit("room_join_error", { 30 | error: "Room is full please choose another room to play!", 31 | }); 32 | } else { 33 | await socket.join(message.roomId); 34 | socket.emit("room_joined"); 35 | 36 | if (io.sockets.adapter.rooms.get(message.roomId).size === 2) { 37 | socket.emit("start_game", { start: true, symbol: "x" }); 38 | socket 39 | .to(message.roomId) 40 | .emit("start_game", { start: false, symbol: "o" }); 41 | } 42 | } 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /react-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 | -------------------------------------------------------------------------------- /react-client/src/App.tsx: -------------------------------------------------------------------------------- 1 | import React, { useEffect, useState } from "react"; 2 | import styled from "styled-components"; 3 | import "./App.css"; 4 | import { io } from "socket.io-client"; 5 | import socketService from "./services/socketService"; 6 | import { JoinRoom } from "./components/joinRoom"; 7 | import GameContext, { IGameContextProps } from "./gameContext"; 8 | import { Game } from "./components/game"; 9 | 10 | const AppContainer = styled.div` 11 | width: 100%; 12 | height: 100%; 13 | display: flex; 14 | flex-direction: column; 15 | align-items: center; 16 | padding: 1em; 17 | `; 18 | 19 | const WelcomeText = styled.h1` 20 | margin: 0; 21 | color: #8e44ad; 22 | `; 23 | 24 | const MainContainer = styled.div` 25 | width: 100%; 26 | height: 100%; 27 | display: flex; 28 | align-items: center; 29 | justify-content: center; 30 | `; 31 | 32 | function App() { 33 | const [isInRoom, setInRoom] = useState(false); 34 | const [playerSymbol, setPlayerSymbol] = useState<"x" | "o">("x"); 35 | const [isPlayerTurn, setPlayerTurn] = useState(false); 36 | const [isGameStarted, setGameStarted] = useState(false); 37 | 38 | const connectSocket = async () => { 39 | const socket = await socketService 40 | .connect("http://localhost:9000") 41 | .catch((err) => { 42 | console.log("Error: ", err); 43 | }); 44 | }; 45 | 46 | useEffect(() => { 47 | connectSocket(); 48 | }, []); 49 | 50 | const gameContextValue: IGameContextProps = { 51 | isInRoom, 52 | setInRoom, 53 | playerSymbol, 54 | setPlayerSymbol, 55 | isPlayerTurn, 56 | setPlayerTurn, 57 | isGameStarted, 58 | setGameStarted, 59 | }; 60 | 61 | return ( 62 | 63 | 64 | Welcome to Tic-Tac-Toe 65 | 66 | {!isInRoom && } 67 | {isInRoom && } 68 | 69 | 70 | 71 | ); 72 | } 73 | 74 | export default App; 75 | -------------------------------------------------------------------------------- /socketio-server/src/server.ts: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | /** 4 | * Module dependencies. 5 | */ 6 | 7 | import "reflect-metadata"; 8 | import app from "./app"; 9 | var debug = require("debug")("socketio-server:server"); 10 | import * as http from "http"; 11 | import socketServer from "./socket"; 12 | 13 | /** 14 | * Get port from environment and store in Express. 15 | */ 16 | 17 | var port = normalizePort(process.env.PORT || "9000"); 18 | app.set("port", port); 19 | 20 | /** 21 | * Create HTTP server. 22 | */ 23 | 24 | var server = http.createServer(app); 25 | 26 | /** 27 | * Listen on provided port, on all network interfaces. 28 | */ 29 | 30 | server.listen(port); 31 | server.on("error", onError); 32 | server.on("listening", onListening); 33 | 34 | const io = socketServer(server); 35 | 36 | /** 37 | * Normalize a port into a number, string, or false. 38 | */ 39 | 40 | function normalizePort(val) { 41 | var port = parseInt(val, 10); 42 | 43 | if (isNaN(port)) { 44 | // named pipe 45 | return val; 46 | } 47 | 48 | if (port >= 0) { 49 | // port number 50 | return port; 51 | } 52 | 53 | return false; 54 | } 55 | 56 | /** 57 | * Event listener for HTTP server "error" event. 58 | */ 59 | 60 | function onError(error) { 61 | if (error.syscall !== "listen") { 62 | throw error; 63 | } 64 | 65 | var bind = typeof port === "string" ? "Pipe " + port : "Port " + port; 66 | 67 | // handle specific listen errors with friendly messages 68 | switch (error.code) { 69 | case "EACCES": 70 | console.error(bind + " requires elevated privileges"); 71 | process.exit(1); 72 | break; 73 | case "EADDRINUSE": 74 | console.error(bind + " is already in use"); 75 | process.exit(1); 76 | break; 77 | default: 78 | throw error; 79 | } 80 | } 81 | 82 | /** 83 | * Event listener for HTTP server "listening" event. 84 | */ 85 | 86 | function onListening() { 87 | var addr = server.address(); 88 | var bind = typeof addr === "string" ? "pipe " + addr : "port " + addr.port; 89 | debug("Listening on " + bind); 90 | 91 | console.log("Server Running on Port: ", port); 92 | } 93 | -------------------------------------------------------------------------------- /react-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 | -------------------------------------------------------------------------------- /react-client/src/logo.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /react-client/src/components/joinRoom/index.tsx: -------------------------------------------------------------------------------- 1 | import React, { useContext, useState } from "react"; 2 | import styled from "styled-components"; 3 | import gameContext from "../../gameContext"; 4 | import gameService from "../../services/gameService"; 5 | import socketService from "../../services/socketService"; 6 | 7 | interface IJoinRoomProps {} 8 | 9 | const JoinRoomContainer = styled.div` 10 | width: 100%; 11 | height: 100%; 12 | display: flex; 13 | flex-direction: column; 14 | align-items: center; 15 | justify-content: center; 16 | margin-top: 2em; 17 | `; 18 | 19 | const RoomIdInput = styled.input` 20 | height: 30px; 21 | width: 20em; 22 | font-size: 17px; 23 | outline: none; 24 | border: 1px solid #8e44ad; 25 | border-radius: 3px; 26 | padding: 0 10px; 27 | `; 28 | 29 | const JoinButton = styled.button` 30 | outline: none; 31 | background-color: #8e44ad; 32 | color: #fff; 33 | font-size: 17px; 34 | border: 2px solid transparent; 35 | border-radius: 5px; 36 | padding: 4px 18px; 37 | transition: all 230ms ease-in-out; 38 | margin-top: 1em; 39 | cursor: pointer; 40 | 41 | &:hover { 42 | background-color: transparent; 43 | border: 2px solid #8e44ad; 44 | color: #8e44ad; 45 | } 46 | `; 47 | 48 | export function JoinRoom(props: IJoinRoomProps) { 49 | const [roomName, setRoomName] = useState(""); 50 | const [isJoining, setJoining] = useState(false); 51 | 52 | const { setInRoom, isInRoom } = useContext(gameContext); 53 | 54 | const handleRoomNameChange = (e: React.ChangeEvent) => { 55 | const value = e.target.value; 56 | setRoomName(value); 57 | }; 58 | 59 | const joinRoom = async (e: React.FormEvent) => { 60 | e.preventDefault(); 61 | 62 | const socket = socketService.socket; 63 | if (!roomName || roomName.trim() === "" || !socket) return; 64 | 65 | setJoining(true); 66 | 67 | const joined = await gameService 68 | .joinGameRoom(socket, roomName) 69 | .catch((err) => { 70 | alert(err); 71 | }); 72 | 73 | if (joined) setInRoom(true); 74 | 75 | setJoining(false); 76 | }; 77 | 78 | return ( 79 |
80 | 81 |

Enter Room ID to Join the Game

82 | 87 | 88 | {isJoining ? "Joining..." : "Joing"} 89 | 90 |
91 |
92 | ); 93 | } 94 | -------------------------------------------------------------------------------- /react-client/src/components/game/index.tsx: -------------------------------------------------------------------------------- 1 | import React, { useContext, useEffect, useState } from "react"; 2 | import styled from "styled-components"; 3 | import gameContext from "../../gameContext"; 4 | import gameService from "../../services/gameService"; 5 | import socketService from "../../services/socketService"; 6 | 7 | const GameContainer = styled.div` 8 | display: flex; 9 | flex-direction: column; 10 | font-family: "Zen Tokyo Zoo", cursive; 11 | position: relative; 12 | `; 13 | 14 | const RowContainer = styled.div` 15 | width: 100%; 16 | display: flex; 17 | `; 18 | 19 | interface ICellProps { 20 | borderTop?: boolean; 21 | borderRight?: boolean; 22 | borderLeft?: boolean; 23 | borderBottom?: boolean; 24 | } 25 | 26 | const Cell = styled.div` 27 | width: 13em; 28 | height: 9em; 29 | display: flex; 30 | align-items: center; 31 | justify-content: center; 32 | border-radius: 20px; 33 | cursor: pointer; 34 | border-top: ${({ borderTop }) => borderTop && "3px solid #8e44ad"}; 35 | border-left: ${({ borderLeft }) => borderLeft && "3px solid #8e44ad"}; 36 | border-bottom: ${({ borderBottom }) => borderBottom && "3px solid #8e44ad"}; 37 | border-right: ${({ borderRight }) => borderRight && "3px solid #8e44ad"}; 38 | transition: all 270ms ease-in-out; 39 | 40 | &:hover { 41 | background-color: #8d44ad28; 42 | } 43 | `; 44 | 45 | const PlayStopper = styled.div` 46 | width: 100%; 47 | height: 100%; 48 | position: absolute; 49 | bottom: 0; 50 | left: 0; 51 | z-index: 99; 52 | cursor: default; 53 | `; 54 | 55 | const X = styled.span` 56 | font-size: 100px; 57 | color: #8e44ad; 58 | &::after { 59 | content: "X"; 60 | } 61 | `; 62 | 63 | const O = styled.span` 64 | font-size: 100px; 65 | color: #8e44ad; 66 | &::after { 67 | content: "O"; 68 | } 69 | `; 70 | 71 | export type IPlayMatrix = Array>; 72 | export interface IStartGame { 73 | start: boolean; 74 | symbol: "x" | "o"; 75 | } 76 | 77 | export function Game() { 78 | const [matrix, setMatrix] = useState([ 79 | [null, null, null], 80 | [null, null, null], 81 | [null, null, null], 82 | ]); 83 | 84 | const { 85 | playerSymbol, 86 | setPlayerSymbol, 87 | setPlayerTurn, 88 | isPlayerTurn, 89 | setGameStarted, 90 | isGameStarted, 91 | } = useContext(gameContext); 92 | 93 | const checkGameState = (matrix: IPlayMatrix) => { 94 | for (let i = 0; i < matrix.length; i++) { 95 | let row = []; 96 | for (let j = 0; j < matrix[i].length; j++) { 97 | row.push(matrix[i][j]); 98 | } 99 | 100 | if (row.every((value) => value && value === playerSymbol)) { 101 | return [true, false]; 102 | } else if (row.every((value) => value && value !== playerSymbol)) { 103 | return [false, true]; 104 | } 105 | } 106 | 107 | for (let i = 0; i < matrix.length; i++) { 108 | let column = []; 109 | for (let j = 0; j < matrix[i].length; j++) { 110 | column.push(matrix[j][i]); 111 | } 112 | 113 | if (column.every((value) => value && value === playerSymbol)) { 114 | return [true, false]; 115 | } else if (column.every((value) => value && value !== playerSymbol)) { 116 | return [false, true]; 117 | } 118 | } 119 | 120 | if (matrix[1][1]) { 121 | if (matrix[0][0] === matrix[1][1] && matrix[2][2] === matrix[1][1]) { 122 | if (matrix[1][1] === playerSymbol) return [true, false]; 123 | else return [false, true]; 124 | } 125 | 126 | if (matrix[2][0] === matrix[1][1] && matrix[0][2] === matrix[1][1]) { 127 | if (matrix[1][1] === playerSymbol) return [true, false]; 128 | else return [false, true]; 129 | } 130 | } 131 | 132 | //Check for a tie 133 | if (matrix.every((m) => m.every((v) => v !== null))) { 134 | return [true, true]; 135 | } 136 | 137 | return [false, false]; 138 | }; 139 | 140 | const updateGameMatrix = (column: number, row: number, symbol: "x" | "o") => { 141 | const newMatrix = [...matrix]; 142 | 143 | if (newMatrix[row][column] === null || newMatrix[row][column] === "null") { 144 | newMatrix[row][column] = symbol; 145 | setMatrix(newMatrix); 146 | } 147 | 148 | if (socketService.socket) { 149 | gameService.updateGame(socketService.socket, newMatrix); 150 | const [currentPlayerWon, otherPlayerWon] = checkGameState(newMatrix); 151 | if (currentPlayerWon && otherPlayerWon) { 152 | gameService.gameWin(socketService.socket, "The Game is a TIE!"); 153 | alert("The Game is a TIE!"); 154 | } else if (currentPlayerWon && !otherPlayerWon) { 155 | gameService.gameWin(socketService.socket, "You Lost!"); 156 | alert("You Won!"); 157 | } 158 | 159 | setPlayerTurn(false); 160 | } 161 | }; 162 | 163 | const handleGameUpdate = () => { 164 | if (socketService.socket) 165 | gameService.onGameUpdate(socketService.socket, (newMatrix) => { 166 | setMatrix(newMatrix); 167 | checkGameState(newMatrix); 168 | setPlayerTurn(true); 169 | }); 170 | }; 171 | 172 | const handleGameStart = () => { 173 | if (socketService.socket) 174 | gameService.onStartGame(socketService.socket, (options) => { 175 | setGameStarted(true); 176 | setPlayerSymbol(options.symbol); 177 | if (options.start) setPlayerTurn(true); 178 | else setPlayerTurn(false); 179 | }); 180 | }; 181 | 182 | const handleGameWin = () => { 183 | if (socketService.socket) 184 | gameService.onGameWin(socketService.socket, (message) => { 185 | console.log("Here", message); 186 | setPlayerTurn(false); 187 | alert(message); 188 | }); 189 | }; 190 | 191 | useEffect(() => { 192 | handleGameUpdate(); 193 | handleGameStart(); 194 | handleGameWin(); 195 | }, []); 196 | 197 | return ( 198 | 199 | {!isGameStarted && ( 200 |

Waiting for Other Player to Join to Start the Game!

201 | )} 202 | {(!isGameStarted || !isPlayerTurn) && } 203 | {matrix.map((row, rowIdx) => { 204 | return ( 205 | 206 | {row.map((column, columnIdx) => ( 207 | 0} 210 | borderBottom={rowIdx < 2} 211 | borderTop={rowIdx > 0} 212 | onClick={() => 213 | updateGameMatrix(columnIdx, rowIdx, playerSymbol) 214 | } 215 | > 216 | {column && column !== "null" ? ( 217 | column === "x" ? ( 218 | 219 | ) : ( 220 | 221 | ) 222 | ) : null} 223 | 224 | ))} 225 | 226 | ); 227 | })} 228 |
229 | ); 230 | } 231 | -------------------------------------------------------------------------------- /socketio-server/yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | "@sindresorhus/is@^0.14.0": 6 | version "0.14.0" 7 | resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-0.14.0.tgz#9fb3a3cf3132328151f353de4632e01e52102bea" 8 | integrity sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ== 9 | 10 | "@szmarczak/http-timer@^1.1.2": 11 | version "1.1.2" 12 | resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-1.1.2.tgz#b1665e2c461a2cd92f4c1bbf50d5454de0d4b421" 13 | integrity sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA== 14 | dependencies: 15 | defer-to-connect "^1.0.1" 16 | 17 | "@tsconfig/node10@^1.0.7": 18 | version "1.0.8" 19 | resolved "https://registry.yarnpkg.com/@tsconfig/node10/-/node10-1.0.8.tgz#c1e4e80d6f964fbecb3359c43bd48b40f7cadad9" 20 | integrity sha512-6XFfSQmMgq0CFLY1MslA/CPUfhIL919M1rMsa5lP2P097N2Wd1sSX0tx1u4olM16fLNhtHZpRhedZJphNJqmZg== 21 | 22 | "@tsconfig/node12@^1.0.7": 23 | version "1.0.9" 24 | resolved "https://registry.yarnpkg.com/@tsconfig/node12/-/node12-1.0.9.tgz#62c1f6dee2ebd9aead80dc3afa56810e58e1a04c" 25 | integrity sha512-/yBMcem+fbvhSREH+s14YJi18sp7J9jpuhYByADT2rypfajMZZN4WQ6zBGgBKp53NKmqI36wFYDb3yaMPurITw== 26 | 27 | "@tsconfig/node14@^1.0.0": 28 | version "1.0.1" 29 | resolved "https://registry.yarnpkg.com/@tsconfig/node14/-/node14-1.0.1.tgz#95f2d167ffb9b8d2068b0b235302fafd4df711f2" 30 | integrity sha512-509r2+yARFfHHE7T6Puu2jjkoycftovhXRqW328PDXTVGKihlb1P8Z9mMZH04ebyajfRY7dedfGynlrFHJUQCg== 31 | 32 | "@tsconfig/node16@^1.0.1": 33 | version "1.0.1" 34 | resolved "https://registry.yarnpkg.com/@tsconfig/node16/-/node16-1.0.1.tgz#a6ca6a9a0ff366af433f42f5f0e124794ff6b8f1" 35 | integrity sha512-FTgBI767POY/lKNDNbIzgAX6miIDBs6NTCbdlDb8TrWovHsSvaVIZDlTqym29C6UqhzwcJx4CYr+AlrMywA0cA== 36 | 37 | "@types/component-emitter@^1.2.10": 38 | version "1.2.10" 39 | resolved "https://registry.yarnpkg.com/@types/component-emitter/-/component-emitter-1.2.10.tgz#ef5b1589b9f16544642e473db5ea5639107ef3ea" 40 | integrity sha512-bsjleuRKWmGqajMerkzox19aGbscQX5rmmvvXl3wlIp5gMG1HgkiwPxsN5p070fBDKTNSPgojVbuY1+HWMbFhg== 41 | 42 | "@types/cookie@^0.4.0": 43 | version "0.4.0" 44 | resolved "https://registry.yarnpkg.com/@types/cookie/-/cookie-0.4.0.tgz#14f854c0f93d326e39da6e3b6f34f7d37513d108" 45 | integrity sha512-y7mImlc/rNkvCRmg8gC3/lj87S7pTUIJ6QGjwHR9WQJcFs+ZMTOaoPrkdFA/YdbuqVEmEbb5RdhVxMkAcgOnpg== 46 | 47 | "@types/cors@^2.8.8": 48 | version "2.8.10" 49 | resolved "https://registry.yarnpkg.com/@types/cors/-/cors-2.8.10.tgz#61cc8469849e5bcdd0c7044122265c39cec10cf4" 50 | integrity sha512-C7srjHiVG3Ey1nR6d511dtDkCEjxuN9W1HWAEjGq8kpcwmNM6JJkpC0xvabM7BXTG2wDq8Eu33iH9aQKa7IvLQ== 51 | 52 | "@types/node@>=10.0.0", "@types/node@^16.0.0": 53 | version "16.0.0" 54 | resolved "https://registry.yarnpkg.com/@types/node/-/node-16.0.0.tgz#067a6c49dc7a5c2412a505628e26902ae967bf6f" 55 | integrity sha512-TmCW5HoZ2o2/z2EYi109jLqIaPIi9y/lc2LmDCWzuCi35bcaQ+OtUh6nwBiFK7SOu25FAU5+YKdqFZUwtqGSdg== 56 | 57 | abbrev@1: 58 | version "1.1.1" 59 | resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" 60 | integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== 61 | 62 | accepts@~1.3.4, accepts@~1.3.5: 63 | version "1.3.7" 64 | resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.7.tgz#531bc726517a3b2b41f850021c6cc15eaab507cd" 65 | integrity sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA== 66 | dependencies: 67 | mime-types "~2.1.24" 68 | negotiator "0.6.2" 69 | 70 | acorn-globals@^1.0.3: 71 | version "1.0.9" 72 | resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-1.0.9.tgz#55bb5e98691507b74579d0513413217c380c54cf" 73 | integrity sha1-VbtemGkVB7dFedBRNBMhfDgMVM8= 74 | dependencies: 75 | acorn "^2.1.0" 76 | 77 | acorn@^1.0.1: 78 | version "1.2.2" 79 | resolved "https://registry.yarnpkg.com/acorn/-/acorn-1.2.2.tgz#c8ce27de0acc76d896d2b1fad3df588d9e82f014" 80 | integrity sha1-yM4n3grMdtiW0rH6099YjZ6C8BQ= 81 | 82 | acorn@^2.1.0: 83 | version "2.7.0" 84 | resolved "https://registry.yarnpkg.com/acorn/-/acorn-2.7.0.tgz#ab6e7d9d886aaca8b085bc3312b79a198433f0e7" 85 | integrity sha1-q259nYhqrKiwhbwzEreaGYQz8Oc= 86 | 87 | after@0.8.2: 88 | version "0.8.2" 89 | resolved "https://registry.yarnpkg.com/after/-/after-0.8.2.tgz#fedb394f9f0e02aa9768e702bda23b505fae7e1f" 90 | integrity sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8= 91 | 92 | align-text@^0.1.1, align-text@^0.1.3: 93 | version "0.1.4" 94 | resolved "https://registry.yarnpkg.com/align-text/-/align-text-0.1.4.tgz#0cd90a561093f35d0a99256c22b7069433fad117" 95 | integrity sha1-DNkKVhCT810KmSVsIrcGlDP60Rc= 96 | dependencies: 97 | kind-of "^3.0.2" 98 | longest "^1.0.1" 99 | repeat-string "^1.5.2" 100 | 101 | amdefine@>=0.0.4: 102 | version "1.0.1" 103 | resolved "https://registry.yarnpkg.com/amdefine/-/amdefine-1.0.1.tgz#4a5282ac164729e93619bcfd3ad151f817ce91f5" 104 | integrity sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU= 105 | 106 | ansi-align@^3.0.0: 107 | version "3.0.0" 108 | resolved "https://registry.yarnpkg.com/ansi-align/-/ansi-align-3.0.0.tgz#b536b371cf687caaef236c18d3e21fe3797467cb" 109 | integrity sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw== 110 | dependencies: 111 | string-width "^3.0.0" 112 | 113 | ansi-regex@^4.1.0: 114 | version "4.1.0" 115 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz#8b9f8f08cf1acb843756a839ca8c7e3168c51997" 116 | integrity sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg== 117 | 118 | ansi-regex@^5.0.0: 119 | version "5.0.0" 120 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75" 121 | integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg== 122 | 123 | ansi-styles@^4.1.0: 124 | version "4.3.0" 125 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" 126 | integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== 127 | dependencies: 128 | color-convert "^2.0.1" 129 | 130 | anymatch@~3.1.2: 131 | version "3.1.2" 132 | resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" 133 | integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== 134 | dependencies: 135 | normalize-path "^3.0.0" 136 | picomatch "^2.0.4" 137 | 138 | arg@^4.1.0: 139 | version "4.1.3" 140 | resolved "https://registry.yarnpkg.com/arg/-/arg-4.1.3.tgz#269fc7ad5b8e42cb63c896d5666017261c144089" 141 | integrity sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA== 142 | 143 | array-flatten@1.1.1: 144 | version "1.1.1" 145 | resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" 146 | integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= 147 | 148 | arraybuffer.slice@~0.0.7: 149 | version "0.0.7" 150 | resolved "https://registry.yarnpkg.com/arraybuffer.slice/-/arraybuffer.slice-0.0.7.tgz#3bbc4275dd584cc1b10809b89d4e8b63a69e7675" 151 | integrity sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog== 152 | 153 | asap@~1.0.0: 154 | version "1.0.0" 155 | resolved "https://registry.yarnpkg.com/asap/-/asap-1.0.0.tgz#b2a45da5fdfa20b0496fc3768cc27c12fa916a7d" 156 | integrity sha1-sqRdpf36ILBJb8N2jMJ8EvqRan0= 157 | 158 | backo2@1.0.2: 159 | version "1.0.2" 160 | resolved "https://registry.yarnpkg.com/backo2/-/backo2-1.0.2.tgz#31ab1ac8b129363463e35b3ebb69f4dfcfba7947" 161 | integrity sha1-MasayLEpNjRj41s+u2n038+6eUc= 162 | 163 | balanced-match@^1.0.0: 164 | version "1.0.2" 165 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" 166 | integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== 167 | 168 | base64-arraybuffer@0.1.4: 169 | version "0.1.4" 170 | resolved "https://registry.yarnpkg.com/base64-arraybuffer/-/base64-arraybuffer-0.1.4.tgz#9818c79e059b1355f97e0428a017c838e90ba812" 171 | integrity sha1-mBjHngWbE1X5fgQooBfIOOkLqBI= 172 | 173 | base64id@2.0.0, base64id@~2.0.0: 174 | version "2.0.0" 175 | resolved "https://registry.yarnpkg.com/base64id/-/base64id-2.0.0.tgz#2770ac6bc47d312af97a8bf9a634342e0cd25cb6" 176 | integrity sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog== 177 | 178 | basic-auth@~2.0.0: 179 | version "2.0.1" 180 | resolved "https://registry.yarnpkg.com/basic-auth/-/basic-auth-2.0.1.tgz#b998279bf47ce38344b4f3cf916d4679bbf51e3a" 181 | integrity sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg== 182 | dependencies: 183 | safe-buffer "5.1.2" 184 | 185 | binary-extensions@^2.0.0: 186 | version "2.2.0" 187 | resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" 188 | integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== 189 | 190 | blob@0.0.5: 191 | version "0.0.5" 192 | resolved "https://registry.yarnpkg.com/blob/-/blob-0.0.5.tgz#d680eeef25f8cd91ad533f5b01eed48e64caf683" 193 | integrity sha512-gaqbzQPqOoamawKg0LGVd7SzLgXS+JH61oWprSLH+P+abTczqJbhTR8CmJ2u9/bUYNmHTGJx/UEmn6doAvvuig== 194 | 195 | body-parser@1.18.3: 196 | version "1.18.3" 197 | resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.18.3.tgz#5b292198ffdd553b3a0f20ded0592b956955c8b4" 198 | integrity sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ= 199 | dependencies: 200 | bytes "3.0.0" 201 | content-type "~1.0.4" 202 | debug "2.6.9" 203 | depd "~1.1.2" 204 | http-errors "~1.6.3" 205 | iconv-lite "0.4.23" 206 | on-finished "~2.3.0" 207 | qs "6.5.2" 208 | raw-body "2.3.3" 209 | type-is "~1.6.16" 210 | 211 | boxen@^4.2.0: 212 | version "4.2.0" 213 | resolved "https://registry.yarnpkg.com/boxen/-/boxen-4.2.0.tgz#e411b62357d6d6d36587c8ac3d5d974daa070e64" 214 | integrity sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ== 215 | dependencies: 216 | ansi-align "^3.0.0" 217 | camelcase "^5.3.1" 218 | chalk "^3.0.0" 219 | cli-boxes "^2.2.0" 220 | string-width "^4.1.0" 221 | term-size "^2.1.0" 222 | type-fest "^0.8.1" 223 | widest-line "^3.1.0" 224 | 225 | brace-expansion@^1.1.7: 226 | version "1.1.11" 227 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" 228 | integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== 229 | dependencies: 230 | balanced-match "^1.0.0" 231 | concat-map "0.0.1" 232 | 233 | braces@~3.0.2: 234 | version "3.0.2" 235 | resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" 236 | integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== 237 | dependencies: 238 | fill-range "^7.0.1" 239 | 240 | buffer-from@^1.0.0: 241 | version "1.1.1" 242 | resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef" 243 | integrity sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A== 244 | 245 | bytes@3.0.0: 246 | version "3.0.0" 247 | resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.0.0.tgz#d32815404d689699f85a4ea4fa8755dd13a96048" 248 | integrity sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg= 249 | 250 | cacheable-request@^6.0.0: 251 | version "6.1.0" 252 | resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-6.1.0.tgz#20ffb8bd162ba4be11e9567d823db651052ca912" 253 | integrity sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg== 254 | dependencies: 255 | clone-response "^1.0.2" 256 | get-stream "^5.1.0" 257 | http-cache-semantics "^4.0.0" 258 | keyv "^3.0.0" 259 | lowercase-keys "^2.0.0" 260 | normalize-url "^4.1.0" 261 | responselike "^1.0.2" 262 | 263 | camelcase@^1.0.2: 264 | version "1.2.1" 265 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-1.2.1.tgz#9bb5304d2e0b56698b2c758b08a3eaa9daa58a39" 266 | integrity sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk= 267 | 268 | camelcase@^5.3.1: 269 | version "5.3.1" 270 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" 271 | integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== 272 | 273 | center-align@^0.1.1: 274 | version "0.1.3" 275 | resolved "https://registry.yarnpkg.com/center-align/-/center-align-0.1.3.tgz#aa0d32629b6ee972200411cbd4461c907bc2b7ad" 276 | integrity sha1-qg0yYptu6XIgBBHL1EYckHvCt60= 277 | dependencies: 278 | align-text "^0.1.3" 279 | lazy-cache "^1.0.3" 280 | 281 | chalk@^3.0.0: 282 | version "3.0.0" 283 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4" 284 | integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg== 285 | dependencies: 286 | ansi-styles "^4.1.0" 287 | supports-color "^7.1.0" 288 | 289 | character-parser@1.2.1: 290 | version "1.2.1" 291 | resolved "https://registry.yarnpkg.com/character-parser/-/character-parser-1.2.1.tgz#c0dde4ab182713b919b970959a123ecc1a30fcd6" 292 | integrity sha1-wN3kqxgnE7kZuXCVmhI+zBow/NY= 293 | 294 | chokidar@^3.2.2: 295 | version "3.5.2" 296 | resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.2.tgz#dba3976fcadb016f66fd365021d91600d01c1e75" 297 | integrity sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ== 298 | dependencies: 299 | anymatch "~3.1.2" 300 | braces "~3.0.2" 301 | glob-parent "~5.1.2" 302 | is-binary-path "~2.1.0" 303 | is-glob "~4.0.1" 304 | normalize-path "~3.0.0" 305 | readdirp "~3.6.0" 306 | optionalDependencies: 307 | fsevents "~2.3.2" 308 | 309 | ci-info@^2.0.0: 310 | version "2.0.0" 311 | resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" 312 | integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== 313 | 314 | class-transformer@^0.1.6: 315 | version "0.1.10" 316 | resolved "https://registry.yarnpkg.com/class-transformer/-/class-transformer-0.1.10.tgz#350f168ebb4c1f87edb18b98dd973681fc20fff7" 317 | integrity sha512-QiNdUxEvTBiUtc0KiapGVHhgaqGQVEhOfL9UEBnb9xRfcwmDJT5ijIDwcwJUTwXaT/kGvZZB4JCGsiuR5adX6g== 318 | 319 | clean-css@^3.1.9: 320 | version "3.4.28" 321 | resolved "https://registry.yarnpkg.com/clean-css/-/clean-css-3.4.28.tgz#bf1945e82fc808f55695e6ddeaec01400efd03ff" 322 | integrity sha1-vxlF6C/ICPVWlebd6uwBQA79A/8= 323 | dependencies: 324 | commander "2.8.x" 325 | source-map "0.4.x" 326 | 327 | cli-boxes@^2.2.0: 328 | version "2.2.1" 329 | resolved "https://registry.yarnpkg.com/cli-boxes/-/cli-boxes-2.2.1.tgz#ddd5035d25094fce220e9cab40a45840a440318f" 330 | integrity sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw== 331 | 332 | cliui@^2.1.0: 333 | version "2.1.0" 334 | resolved "https://registry.yarnpkg.com/cliui/-/cliui-2.1.0.tgz#4b475760ff80264c762c3a1719032e91c7fea0d1" 335 | integrity sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE= 336 | dependencies: 337 | center-align "^0.1.1" 338 | right-align "^0.1.1" 339 | wordwrap "0.0.2" 340 | 341 | clone-response@^1.0.2: 342 | version "1.0.2" 343 | resolved "https://registry.yarnpkg.com/clone-response/-/clone-response-1.0.2.tgz#d1dc973920314df67fbeb94223b4ee350239e96b" 344 | integrity sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws= 345 | dependencies: 346 | mimic-response "^1.0.0" 347 | 348 | color-convert@^2.0.1: 349 | version "2.0.1" 350 | resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" 351 | integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== 352 | dependencies: 353 | color-name "~1.1.4" 354 | 355 | color-name@~1.1.4: 356 | version "1.1.4" 357 | resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" 358 | integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== 359 | 360 | commander@2.8.x: 361 | version "2.8.1" 362 | resolved "https://registry.yarnpkg.com/commander/-/commander-2.8.1.tgz#06be367febfda0c330aa1e2a072d3dc9762425d4" 363 | integrity sha1-Br42f+v9oMMwqh4qBy09yXYkJdQ= 364 | dependencies: 365 | graceful-readlink ">= 1.0.0" 366 | 367 | commander@~2.6.0: 368 | version "2.6.0" 369 | resolved "https://registry.yarnpkg.com/commander/-/commander-2.6.0.tgz#9df7e52fb2a0cb0fb89058ee80c3104225f37e1d" 370 | integrity sha1-nfflL7Kgyw+4kFjugMMQQiXzfh0= 371 | 372 | component-bind@1.0.0: 373 | version "1.0.0" 374 | resolved "https://registry.yarnpkg.com/component-bind/-/component-bind-1.0.0.tgz#00c608ab7dcd93897c0009651b1d3a8e1e73bbd1" 375 | integrity sha1-AMYIq33Nk4l8AAllGx06jh5zu9E= 376 | 377 | component-emitter@1.2.1: 378 | version "1.2.1" 379 | resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.2.1.tgz#137918d6d78283f7df7a6b7c5a63e140e69425e6" 380 | integrity sha1-E3kY1teCg/ffemt8WmPhQOaUJeY= 381 | 382 | component-emitter@~1.3.0: 383 | version "1.3.0" 384 | resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz#16e4070fba8ae29b679f2215853ee181ab2eabc0" 385 | integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== 386 | 387 | component-inherit@0.0.3: 388 | version "0.0.3" 389 | resolved "https://registry.yarnpkg.com/component-inherit/-/component-inherit-0.0.3.tgz#645fc4adf58b72b649d5cae65135619db26ff143" 390 | integrity sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM= 391 | 392 | concat-map@0.0.1: 393 | version "0.0.1" 394 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 395 | integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= 396 | 397 | configstore@^5.0.1: 398 | version "5.0.1" 399 | resolved "https://registry.yarnpkg.com/configstore/-/configstore-5.0.1.tgz#d365021b5df4b98cdd187d6a3b0e3f6a7cc5ed96" 400 | integrity sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA== 401 | dependencies: 402 | dot-prop "^5.2.0" 403 | graceful-fs "^4.1.2" 404 | make-dir "^3.0.0" 405 | unique-string "^2.0.0" 406 | write-file-atomic "^3.0.0" 407 | xdg-basedir "^4.0.0" 408 | 409 | constantinople@~3.0.1: 410 | version "3.0.2" 411 | resolved "https://registry.yarnpkg.com/constantinople/-/constantinople-3.0.2.tgz#4b945d9937907bcd98ee575122c3817516544141" 412 | integrity sha1-S5RdmTeQe82Y7ldRIsOBdRZUQUE= 413 | dependencies: 414 | acorn "^2.1.0" 415 | 416 | content-disposition@0.5.2: 417 | version "0.5.2" 418 | resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.2.tgz#0cf68bb9ddf5f2be7961c3a85178cb85dba78cb4" 419 | integrity sha1-DPaLud318r55YcOoUXjLhdunjLQ= 420 | 421 | content-type@~1.0.4: 422 | version "1.0.4" 423 | resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" 424 | integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== 425 | 426 | cookie-parser@~1.4.4: 427 | version "1.4.5" 428 | resolved "https://registry.yarnpkg.com/cookie-parser/-/cookie-parser-1.4.5.tgz#3e572d4b7c0c80f9c61daf604e4336831b5d1d49" 429 | integrity sha512-f13bPUj/gG/5mDr+xLmSxxDsB9DQiTIfhJS/sqjrmfAWiAN+x2O4i/XguTL9yDZ+/IFDanJ+5x7hC4CXT9Tdzw== 430 | dependencies: 431 | cookie "0.4.0" 432 | cookie-signature "1.0.6" 433 | 434 | cookie-signature@1.0.6: 435 | version "1.0.6" 436 | resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" 437 | integrity sha1-4wOogrNCzD7oylE6eZmXNNqzriw= 438 | 439 | cookie@0.3.1: 440 | version "0.3.1" 441 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.3.1.tgz#e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb" 442 | integrity sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s= 443 | 444 | cookie@0.4.0: 445 | version "0.4.0" 446 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.0.tgz#beb437e7022b3b6d49019d088665303ebe9c14ba" 447 | integrity sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg== 448 | 449 | cookie@~0.4.1: 450 | version "0.4.1" 451 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.1.tgz#afd713fe26ebd21ba95ceb61f9a8116e50a537d1" 452 | integrity sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA== 453 | 454 | cors@^2.8.5, cors@~2.8.5: 455 | version "2.8.5" 456 | resolved "https://registry.yarnpkg.com/cors/-/cors-2.8.5.tgz#eac11da51592dd86b9f06f6e7ac293b3df875d29" 457 | integrity sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g== 458 | dependencies: 459 | object-assign "^4" 460 | vary "^1" 461 | 462 | create-require@^1.1.0: 463 | version "1.1.1" 464 | resolved "https://registry.yarnpkg.com/create-require/-/create-require-1.1.1.tgz#c1d7e8f1e5f6cfc9ff65f9cd352d37348756c333" 465 | integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== 466 | 467 | crypto-random-string@^2.0.0: 468 | version "2.0.0" 469 | resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-2.0.0.tgz#ef2a7a966ec11083388369baa02ebead229b30d5" 470 | integrity sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA== 471 | 472 | css-parse@1.0.4: 473 | version "1.0.4" 474 | resolved "https://registry.yarnpkg.com/css-parse/-/css-parse-1.0.4.tgz#38b0503fbf9da9f54e9c1dbda60e145c77117bdd" 475 | integrity sha1-OLBQP7+dqfVOnB29pg4UXHcRe90= 476 | 477 | css-stringify@1.0.5: 478 | version "1.0.5" 479 | resolved "https://registry.yarnpkg.com/css-stringify/-/css-stringify-1.0.5.tgz#b0d042946db2953bb9d292900a6cb5f6d0122031" 480 | integrity sha1-sNBClG2ylTu50pKQCmy19tASIDE= 481 | 482 | css@~1.0.8: 483 | version "1.0.8" 484 | resolved "https://registry.yarnpkg.com/css/-/css-1.0.8.tgz#9386811ca82bccc9ee7fb5a732b1e2a317c8a3e7" 485 | integrity sha1-k4aBHKgrzMnuf7WnMrHioxfIo+c= 486 | dependencies: 487 | css-parse "1.0.4" 488 | css-stringify "1.0.5" 489 | 490 | debug@2.6.9, debug@^2.2.0, debug@~2.6.9: 491 | version "2.6.9" 492 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" 493 | integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== 494 | dependencies: 495 | ms "2.0.0" 496 | 497 | debug@^3.2.6: 498 | version "3.2.7" 499 | resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" 500 | integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ== 501 | dependencies: 502 | ms "^2.1.1" 503 | 504 | debug@~3.1.0: 505 | version "3.1.0" 506 | resolved "https://registry.yarnpkg.com/debug/-/debug-3.1.0.tgz#5bb5a0672628b64149566ba16819e61518c67261" 507 | integrity sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g== 508 | dependencies: 509 | ms "2.0.0" 510 | 511 | debug@~4.1.0: 512 | version "4.1.1" 513 | resolved "https://registry.yarnpkg.com/debug/-/debug-4.1.1.tgz#3b72260255109c6b589cee050f1d516139664791" 514 | integrity sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw== 515 | dependencies: 516 | ms "^2.1.1" 517 | 518 | debug@~4.3.1: 519 | version "4.3.2" 520 | resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.2.tgz#f0a49c18ac8779e31d4a0c6029dfb76873c7428b" 521 | integrity sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw== 522 | dependencies: 523 | ms "2.1.2" 524 | 525 | decamelize@^1.0.0: 526 | version "1.2.0" 527 | resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" 528 | integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA= 529 | 530 | decompress-response@^3.3.0: 531 | version "3.3.0" 532 | resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-3.3.0.tgz#80a4dd323748384bfa248083622aedec982adff3" 533 | integrity sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M= 534 | dependencies: 535 | mimic-response "^1.0.0" 536 | 537 | deep-extend@^0.6.0: 538 | version "0.6.0" 539 | resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" 540 | integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== 541 | 542 | defer-to-connect@^1.0.1: 543 | version "1.1.3" 544 | resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-1.1.3.tgz#331ae050c08dcf789f8c83a7b81f0ed94f4ac591" 545 | integrity sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ== 546 | 547 | depd@~1.1.2: 548 | version "1.1.2" 549 | resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" 550 | integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= 551 | 552 | destroy@~1.0.4: 553 | version "1.0.4" 554 | resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" 555 | integrity sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA= 556 | 557 | diff@^4.0.1: 558 | version "4.0.2" 559 | resolved "https://registry.yarnpkg.com/diff/-/diff-4.0.2.tgz#60f3aecb89d5fae520c11aa19efc2bb982aade7d" 560 | integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== 561 | 562 | dot-prop@^5.2.0: 563 | version "5.3.0" 564 | resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-5.3.0.tgz#90ccce708cd9cd82cc4dc8c3ddd9abdd55b20e88" 565 | integrity sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q== 566 | dependencies: 567 | is-obj "^2.0.0" 568 | 569 | duplexer3@^0.1.4: 570 | version "0.1.4" 571 | resolved "https://registry.yarnpkg.com/duplexer3/-/duplexer3-0.1.4.tgz#ee01dd1cac0ed3cbc7fdbea37dc0a8f1ce002ce2" 572 | integrity sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI= 573 | 574 | ee-first@1.1.1: 575 | version "1.1.1" 576 | resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" 577 | integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= 578 | 579 | emoji-regex@^7.0.1: 580 | version "7.0.3" 581 | resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz#933a04052860c85e83c122479c4748a8e4c72156" 582 | integrity sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA== 583 | 584 | emoji-regex@^8.0.0: 585 | version "8.0.0" 586 | resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" 587 | integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== 588 | 589 | encodeurl@~1.0.2: 590 | version "1.0.2" 591 | resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" 592 | integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= 593 | 594 | end-of-stream@^1.1.0: 595 | version "1.4.4" 596 | resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" 597 | integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== 598 | dependencies: 599 | once "^1.4.0" 600 | 601 | engine.io-client@~3.5.0: 602 | version "3.5.2" 603 | resolved "https://registry.yarnpkg.com/engine.io-client/-/engine.io-client-3.5.2.tgz#0ef473621294004e9ceebe73cef0af9e36f2f5fa" 604 | integrity sha512-QEqIp+gJ/kMHeUun7f5Vv3bteRHppHH/FMBQX/esFj/fuYfjyUKWGMo3VCvIP/V8bE9KcjHmRZrhIz2Z9oNsDA== 605 | dependencies: 606 | component-emitter "~1.3.0" 607 | component-inherit "0.0.3" 608 | debug "~3.1.0" 609 | engine.io-parser "~2.2.0" 610 | has-cors "1.1.0" 611 | indexof "0.0.1" 612 | parseqs "0.0.6" 613 | parseuri "0.0.6" 614 | ws "~7.4.2" 615 | xmlhttprequest-ssl "~1.6.2" 616 | yeast "0.1.2" 617 | 618 | engine.io-parser@~2.2.0: 619 | version "2.2.1" 620 | resolved "https://registry.yarnpkg.com/engine.io-parser/-/engine.io-parser-2.2.1.tgz#57ce5611d9370ee94f99641b589f94c97e4f5da7" 621 | integrity sha512-x+dN/fBH8Ro8TFwJ+rkB2AmuVw9Yu2mockR/p3W8f8YtExwFgDvBDi0GWyb4ZLkpahtDGZgtr3zLovanJghPqg== 622 | dependencies: 623 | after "0.8.2" 624 | arraybuffer.slice "~0.0.7" 625 | base64-arraybuffer "0.1.4" 626 | blob "0.0.5" 627 | has-binary2 "~1.0.2" 628 | 629 | engine.io-parser@~4.0.0: 630 | version "4.0.2" 631 | resolved "https://registry.yarnpkg.com/engine.io-parser/-/engine.io-parser-4.0.2.tgz#e41d0b3fb66f7bf4a3671d2038a154024edb501e" 632 | integrity sha512-sHfEQv6nmtJrq6TKuIz5kyEKH/qSdK56H/A+7DnAuUPWosnIZAS2NHNcPLmyjtY3cGS/MqJdZbUjW97JU72iYg== 633 | dependencies: 634 | base64-arraybuffer "0.1.4" 635 | 636 | engine.io@~3.5.0: 637 | version "3.5.0" 638 | resolved "https://registry.yarnpkg.com/engine.io/-/engine.io-3.5.0.tgz#9d6b985c8a39b1fe87cd91eb014de0552259821b" 639 | integrity sha512-21HlvPUKaitDGE4GXNtQ7PLP0Sz4aWLddMPw2VTyFz1FVZqu/kZsJUO8WNpKuE/OCL7nkfRaOui2ZCJloGznGA== 640 | dependencies: 641 | accepts "~1.3.4" 642 | base64id "2.0.0" 643 | cookie "~0.4.1" 644 | debug "~4.1.0" 645 | engine.io-parser "~2.2.0" 646 | ws "~7.4.2" 647 | 648 | engine.io@~5.1.0: 649 | version "5.1.1" 650 | resolved "https://registry.yarnpkg.com/engine.io/-/engine.io-5.1.1.tgz#a1f97e51ddf10cbd4db8b5ff4b165aad3760cdd3" 651 | integrity sha512-aMWot7H5aC8L4/T8qMYbLdvKlZOdJTH54FxfdFunTGvhMx1BHkJOntWArsVfgAZVwAO9LC2sryPWRcEeUzCe5w== 652 | dependencies: 653 | accepts "~1.3.4" 654 | base64id "2.0.0" 655 | cookie "~0.4.1" 656 | cors "~2.8.5" 657 | debug "~4.3.1" 658 | engine.io-parser "~4.0.0" 659 | ws "~7.4.2" 660 | 661 | escape-goat@^2.0.0: 662 | version "2.1.1" 663 | resolved "https://registry.yarnpkg.com/escape-goat/-/escape-goat-2.1.1.tgz#1b2dc77003676c457ec760b2dc68edb648188675" 664 | integrity sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q== 665 | 666 | escape-html@~1.0.3: 667 | version "1.0.3" 668 | resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" 669 | integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg= 670 | 671 | etag@~1.8.1: 672 | version "1.8.1" 673 | resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" 674 | integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= 675 | 676 | express@~4.16.1: 677 | version "4.16.4" 678 | resolved "https://registry.yarnpkg.com/express/-/express-4.16.4.tgz#fddef61926109e24c515ea97fd2f1bdbf62df12e" 679 | integrity sha512-j12Uuyb4FMrd/qQAm6uCHAkPtO8FDTRJZBDd5D2KOL2eLaz1yUNdUB/NOIyq0iU4q4cFarsUCrnFDPBcnksuOg== 680 | dependencies: 681 | accepts "~1.3.5" 682 | array-flatten "1.1.1" 683 | body-parser "1.18.3" 684 | content-disposition "0.5.2" 685 | content-type "~1.0.4" 686 | cookie "0.3.1" 687 | cookie-signature "1.0.6" 688 | debug "2.6.9" 689 | depd "~1.1.2" 690 | encodeurl "~1.0.2" 691 | escape-html "~1.0.3" 692 | etag "~1.8.1" 693 | finalhandler "1.1.1" 694 | fresh "0.5.2" 695 | merge-descriptors "1.0.1" 696 | methods "~1.1.2" 697 | on-finished "~2.3.0" 698 | parseurl "~1.3.2" 699 | path-to-regexp "0.1.7" 700 | proxy-addr "~2.0.4" 701 | qs "6.5.2" 702 | range-parser "~1.2.0" 703 | safe-buffer "5.1.2" 704 | send "0.16.2" 705 | serve-static "1.13.2" 706 | setprototypeof "1.1.0" 707 | statuses "~1.4.0" 708 | type-is "~1.6.16" 709 | utils-merge "1.0.1" 710 | vary "~1.1.2" 711 | 712 | fill-range@^7.0.1: 713 | version "7.0.1" 714 | resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" 715 | integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== 716 | dependencies: 717 | to-regex-range "^5.0.1" 718 | 719 | finalhandler@1.1.1: 720 | version "1.1.1" 721 | resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.1.tgz#eebf4ed840079c83f4249038c9d703008301b105" 722 | integrity sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg== 723 | dependencies: 724 | debug "2.6.9" 725 | encodeurl "~1.0.2" 726 | escape-html "~1.0.3" 727 | on-finished "~2.3.0" 728 | parseurl "~1.3.2" 729 | statuses "~1.4.0" 730 | unpipe "~1.0.0" 731 | 732 | forwarded@0.2.0: 733 | version "0.2.0" 734 | resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" 735 | integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== 736 | 737 | fresh@0.5.2: 738 | version "0.5.2" 739 | resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" 740 | integrity sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac= 741 | 742 | fs.realpath@^1.0.0: 743 | version "1.0.0" 744 | resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" 745 | integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= 746 | 747 | fsevents@~2.3.2: 748 | version "2.3.2" 749 | resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" 750 | integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== 751 | 752 | get-stream@^4.1.0: 753 | version "4.1.0" 754 | resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz#c1b255575f3dc21d59bfc79cd3d2b46b1c3a54b5" 755 | integrity sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w== 756 | dependencies: 757 | pump "^3.0.0" 758 | 759 | get-stream@^5.1.0: 760 | version "5.2.0" 761 | resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" 762 | integrity sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA== 763 | dependencies: 764 | pump "^3.0.0" 765 | 766 | glob-parent@~5.1.2: 767 | version "5.1.2" 768 | resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" 769 | integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== 770 | dependencies: 771 | is-glob "^4.0.1" 772 | 773 | glob@^7.1.7: 774 | version "7.1.7" 775 | resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.7.tgz#3b193e9233f01d42d0b3f78294bbeeb418f94a90" 776 | integrity sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ== 777 | dependencies: 778 | fs.realpath "^1.0.0" 779 | inflight "^1.0.4" 780 | inherits "2" 781 | minimatch "^3.0.4" 782 | once "^1.3.0" 783 | path-is-absolute "^1.0.0" 784 | 785 | global-dirs@^2.0.1: 786 | version "2.1.0" 787 | resolved "https://registry.yarnpkg.com/global-dirs/-/global-dirs-2.1.0.tgz#e9046a49c806ff04d6c1825e196c8f0091e8df4d" 788 | integrity sha512-MG6kdOUh/xBnyo9cJFeIKkLEc1AyFq42QTU4XiX51i2NEdxLxLWXIjEjmqKeSuKR7pAZjTqUVoT2b2huxVLgYQ== 789 | dependencies: 790 | ini "1.3.7" 791 | 792 | got@^9.6.0: 793 | version "9.6.0" 794 | resolved "https://registry.yarnpkg.com/got/-/got-9.6.0.tgz#edf45e7d67f99545705de1f7bbeeeb121765ed85" 795 | integrity sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q== 796 | dependencies: 797 | "@sindresorhus/is" "^0.14.0" 798 | "@szmarczak/http-timer" "^1.1.2" 799 | cacheable-request "^6.0.0" 800 | decompress-response "^3.3.0" 801 | duplexer3 "^0.1.4" 802 | get-stream "^4.1.0" 803 | lowercase-keys "^1.0.1" 804 | mimic-response "^1.0.1" 805 | p-cancelable "^1.0.0" 806 | to-readable-stream "^1.0.0" 807 | url-parse-lax "^3.0.0" 808 | 809 | graceful-fs@^4.1.2: 810 | version "4.2.6" 811 | resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.6.tgz#ff040b2b0853b23c3d31027523706f1885d76bee" 812 | integrity sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ== 813 | 814 | "graceful-readlink@>= 1.0.0": 815 | version "1.0.1" 816 | resolved "https://registry.yarnpkg.com/graceful-readlink/-/graceful-readlink-1.0.1.tgz#4cafad76bc62f02fa039b2f94e9a3dd3a391a725" 817 | integrity sha1-TK+tdrxi8C+gObL5Tpo906ORpyU= 818 | 819 | has-binary2@~1.0.2: 820 | version "1.0.3" 821 | resolved "https://registry.yarnpkg.com/has-binary2/-/has-binary2-1.0.3.tgz#7776ac627f3ea77250cfc332dab7ddf5e4f5d11d" 822 | integrity sha512-G1LWKhDSvhGeAQ8mPVQlqNcOB2sJdwATtZKl2pDKKHfpf/rYj24lkinxf69blJbnsvtqqNU+L3SL50vzZhXOnw== 823 | dependencies: 824 | isarray "2.0.1" 825 | 826 | has-cors@1.1.0: 827 | version "1.1.0" 828 | resolved "https://registry.yarnpkg.com/has-cors/-/has-cors-1.1.0.tgz#5e474793f7ea9843d1bb99c23eef49ff126fff39" 829 | integrity sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk= 830 | 831 | has-flag@^3.0.0: 832 | version "3.0.0" 833 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" 834 | integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= 835 | 836 | has-flag@^4.0.0: 837 | version "4.0.0" 838 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" 839 | integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== 840 | 841 | has-yarn@^2.1.0: 842 | version "2.1.0" 843 | resolved "https://registry.yarnpkg.com/has-yarn/-/has-yarn-2.1.0.tgz#137e11354a7b5bf11aa5cb649cf0c6f3ff2b2e77" 844 | integrity sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw== 845 | 846 | http-cache-semantics@^4.0.0: 847 | version "4.1.0" 848 | resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" 849 | integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== 850 | 851 | http-errors@1.6.3, http-errors@~1.6.2, http-errors@~1.6.3: 852 | version "1.6.3" 853 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.3.tgz#8b55680bb4be283a0b5bf4ea2e38580be1d9320d" 854 | integrity sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0= 855 | dependencies: 856 | depd "~1.1.2" 857 | inherits "2.0.3" 858 | setprototypeof "1.1.0" 859 | statuses ">= 1.4.0 < 2" 860 | 861 | iconv-lite@0.4.23: 862 | version "0.4.23" 863 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.23.tgz#297871f63be507adcfbfca715d0cd0eed84e9a63" 864 | integrity sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA== 865 | dependencies: 866 | safer-buffer ">= 2.1.2 < 3" 867 | 868 | ignore-by-default@^1.0.1: 869 | version "1.0.1" 870 | resolved "https://registry.yarnpkg.com/ignore-by-default/-/ignore-by-default-1.0.1.tgz#48ca6d72f6c6a3af00a9ad4ae6876be3889e2b09" 871 | integrity sha1-SMptcvbGo68Aqa1K5odr44ieKwk= 872 | 873 | import-lazy@^2.1.0: 874 | version "2.1.0" 875 | resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-2.1.0.tgz#05698e3d45c88e8d7e9d92cb0584e77f096f3e43" 876 | integrity sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM= 877 | 878 | imurmurhash@^0.1.4: 879 | version "0.1.4" 880 | resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" 881 | integrity sha1-khi5srkoojixPcT7a21XbyMUU+o= 882 | 883 | indexof@0.0.1: 884 | version "0.0.1" 885 | resolved "https://registry.yarnpkg.com/indexof/-/indexof-0.0.1.tgz#82dc336d232b9062179d05ab3293a66059fd435d" 886 | integrity sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10= 887 | 888 | inflight@^1.0.4: 889 | version "1.0.6" 890 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 891 | integrity sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk= 892 | dependencies: 893 | once "^1.3.0" 894 | wrappy "1" 895 | 896 | inherits@2: 897 | version "2.0.4" 898 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" 899 | integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== 900 | 901 | inherits@2.0.3: 902 | version "2.0.3" 903 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" 904 | integrity sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4= 905 | 906 | ini@1.3.7: 907 | version "1.3.7" 908 | resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.7.tgz#a09363e1911972ea16d7a8851005d84cf09a9a84" 909 | integrity sha512-iKpRpXP+CrP2jyrxvg1kMUpXDyRUFDWurxbnVT1vQPx+Wz9uCYsMIqYuSBLV+PAaZG/d7kRLKRFc9oDMsH+mFQ== 910 | 911 | ini@~1.3.0: 912 | version "1.3.8" 913 | resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" 914 | integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== 915 | 916 | ipaddr.js@1.9.1: 917 | version "1.9.1" 918 | resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" 919 | integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== 920 | 921 | is-binary-path@~2.1.0: 922 | version "2.1.0" 923 | resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" 924 | integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== 925 | dependencies: 926 | binary-extensions "^2.0.0" 927 | 928 | is-buffer@^1.1.5: 929 | version "1.1.6" 930 | resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" 931 | integrity sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w== 932 | 933 | is-ci@^2.0.0: 934 | version "2.0.0" 935 | resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz#6bc6334181810e04b5c22b3d589fdca55026404c" 936 | integrity sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w== 937 | dependencies: 938 | ci-info "^2.0.0" 939 | 940 | is-extglob@^2.1.1: 941 | version "2.1.1" 942 | resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" 943 | integrity sha1-qIwCU1eR8C7TfHahueqXc8gz+MI= 944 | 945 | is-fullwidth-code-point@^2.0.0: 946 | version "2.0.0" 947 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" 948 | integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8= 949 | 950 | is-fullwidth-code-point@^3.0.0: 951 | version "3.0.0" 952 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" 953 | integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== 954 | 955 | is-glob@^4.0.1, is-glob@~4.0.1: 956 | version "4.0.1" 957 | resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" 958 | integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== 959 | dependencies: 960 | is-extglob "^2.1.1" 961 | 962 | is-installed-globally@^0.3.1: 963 | version "0.3.2" 964 | resolved "https://registry.yarnpkg.com/is-installed-globally/-/is-installed-globally-0.3.2.tgz#fd3efa79ee670d1187233182d5b0a1dd00313141" 965 | integrity sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g== 966 | dependencies: 967 | global-dirs "^2.0.1" 968 | is-path-inside "^3.0.1" 969 | 970 | is-npm@^4.0.0: 971 | version "4.0.0" 972 | resolved "https://registry.yarnpkg.com/is-npm/-/is-npm-4.0.0.tgz#c90dd8380696df87a7a6d823c20d0b12bbe3c84d" 973 | integrity sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig== 974 | 975 | is-number@^7.0.0: 976 | version "7.0.0" 977 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" 978 | integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== 979 | 980 | is-obj@^2.0.0: 981 | version "2.0.0" 982 | resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" 983 | integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== 984 | 985 | is-path-inside@^3.0.1: 986 | version "3.0.3" 987 | resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" 988 | integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== 989 | 990 | is-promise@^2.0.0: 991 | version "2.2.2" 992 | resolved "https://registry.yarnpkg.com/is-promise/-/is-promise-2.2.2.tgz#39ab959ccbf9a774cf079f7b40c7a26f763135f1" 993 | integrity sha512-+lP4/6lKUBfQjZ2pdxThZvLUAafmZb8OAxFb8XXtiQmS35INgr85hdOGoEs124ez1FCnZJt6jau/T+alh58QFQ== 994 | 995 | is-promise@~1: 996 | version "1.0.1" 997 | resolved "https://registry.yarnpkg.com/is-promise/-/is-promise-1.0.1.tgz#31573761c057e33c2e91aab9e96da08cefbe76e5" 998 | integrity sha1-MVc3YcBX4zwukaq56W2gjO++duU= 999 | 1000 | is-typedarray@^1.0.0: 1001 | version "1.0.0" 1002 | resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" 1003 | integrity sha1-5HnICFjfDBsR3dppQPlgEfzaSpo= 1004 | 1005 | is-yarn-global@^0.3.0: 1006 | version "0.3.0" 1007 | resolved "https://registry.yarnpkg.com/is-yarn-global/-/is-yarn-global-0.3.0.tgz#d502d3382590ea3004893746754c89139973e232" 1008 | integrity sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw== 1009 | 1010 | isarray@2.0.1: 1011 | version "2.0.1" 1012 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-2.0.1.tgz#a37d94ed9cda2d59865c9f76fe596ee1f338741e" 1013 | integrity sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4= 1014 | 1015 | jade@~1.11.0: 1016 | version "1.11.0" 1017 | resolved "https://registry.yarnpkg.com/jade/-/jade-1.11.0.tgz#9c80e538c12d3fb95c8d9bb9559fa0cc040405fd" 1018 | integrity sha1-nIDlOMEtP7lcjZu5VZ+gzAQEBf0= 1019 | dependencies: 1020 | character-parser "1.2.1" 1021 | clean-css "^3.1.9" 1022 | commander "~2.6.0" 1023 | constantinople "~3.0.1" 1024 | jstransformer "0.0.2" 1025 | mkdirp "~0.5.0" 1026 | transformers "2.1.0" 1027 | uglify-js "^2.4.19" 1028 | void-elements "~2.0.1" 1029 | with "~4.0.0" 1030 | 1031 | json-buffer@3.0.0: 1032 | version "3.0.0" 1033 | resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.0.tgz#5b1f397afc75d677bde8bcfc0e47e1f9a3d9a898" 1034 | integrity sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg= 1035 | 1036 | jstransformer@0.0.2: 1037 | version "0.0.2" 1038 | resolved "https://registry.yarnpkg.com/jstransformer/-/jstransformer-0.0.2.tgz#7aae29a903d196cfa0973d885d3e47947ecd76ab" 1039 | integrity sha1-eq4pqQPRls+glz2IXT5HlH7Ndqs= 1040 | dependencies: 1041 | is-promise "^2.0.0" 1042 | promise "^6.0.1" 1043 | 1044 | keyv@^3.0.0: 1045 | version "3.1.0" 1046 | resolved "https://registry.yarnpkg.com/keyv/-/keyv-3.1.0.tgz#ecc228486f69991e49e9476485a5be1e8fc5c4d9" 1047 | integrity sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA== 1048 | dependencies: 1049 | json-buffer "3.0.0" 1050 | 1051 | kind-of@^3.0.2: 1052 | version "3.2.2" 1053 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64" 1054 | integrity sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ= 1055 | dependencies: 1056 | is-buffer "^1.1.5" 1057 | 1058 | latest-version@^5.0.0: 1059 | version "5.1.0" 1060 | resolved "https://registry.yarnpkg.com/latest-version/-/latest-version-5.1.0.tgz#119dfe908fe38d15dfa43ecd13fa12ec8832face" 1061 | integrity sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA== 1062 | dependencies: 1063 | package-json "^6.3.0" 1064 | 1065 | lazy-cache@^1.0.3: 1066 | version "1.0.4" 1067 | resolved "https://registry.yarnpkg.com/lazy-cache/-/lazy-cache-1.0.4.tgz#a1d78fc3a50474cb80845d3b3b6e1da49a446e8e" 1068 | integrity sha1-odePw6UEdMuAhF07O24dpJpEbo4= 1069 | 1070 | longest@^1.0.1: 1071 | version "1.0.1" 1072 | resolved "https://registry.yarnpkg.com/longest/-/longest-1.0.1.tgz#30a0b2da38f73770e8294a0d22e6625ed77d0097" 1073 | integrity sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc= 1074 | 1075 | lowercase-keys@^1.0.0, lowercase-keys@^1.0.1: 1076 | version "1.0.1" 1077 | resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-1.0.1.tgz#6f9e30b47084d971a7c820ff15a6c5167b74c26f" 1078 | integrity sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA== 1079 | 1080 | lowercase-keys@^2.0.0: 1081 | version "2.0.0" 1082 | resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-2.0.0.tgz#2603e78b7b4b0006cbca2fbcc8a3202558ac9479" 1083 | integrity sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA== 1084 | 1085 | make-dir@^3.0.0: 1086 | version "3.1.0" 1087 | resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" 1088 | integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== 1089 | dependencies: 1090 | semver "^6.0.0" 1091 | 1092 | make-error@^1.1.1: 1093 | version "1.3.6" 1094 | resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.6.tgz#2eb2e37ea9b67c4891f684a1394799af484cf7a2" 1095 | integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== 1096 | 1097 | media-typer@0.3.0: 1098 | version "0.3.0" 1099 | resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" 1100 | integrity sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g= 1101 | 1102 | merge-descriptors@1.0.1: 1103 | version "1.0.1" 1104 | resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" 1105 | integrity sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E= 1106 | 1107 | methods@~1.1.2: 1108 | version "1.1.2" 1109 | resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" 1110 | integrity sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4= 1111 | 1112 | mime-db@1.48.0: 1113 | version "1.48.0" 1114 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.48.0.tgz#e35b31045dd7eada3aaad537ed88a33afbef2d1d" 1115 | integrity sha512-FM3QwxV+TnZYQ2aRqhlKBMHxk10lTbMt3bBkMAp54ddrNeVSfcQYOOKuGuy3Ddrm38I04If834fOUSq1yzslJQ== 1116 | 1117 | mime-types@~2.1.24: 1118 | version "2.1.31" 1119 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.31.tgz#a00d76b74317c61f9c2db2218b8e9f8e9c5c9e6b" 1120 | integrity sha512-XGZnNzm3QvgKxa8dpzyhFTHmpP3l5YNusmne07VUOXxou9CqUqYa/HBy124RqtVh/O2pECas/MOcsDgpilPOPg== 1121 | dependencies: 1122 | mime-db "1.48.0" 1123 | 1124 | mime@1.4.1: 1125 | version "1.4.1" 1126 | resolved "https://registry.yarnpkg.com/mime/-/mime-1.4.1.tgz#121f9ebc49e3766f311a76e1fa1c8003c4b03aa6" 1127 | integrity sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ== 1128 | 1129 | mimic-response@^1.0.0, mimic-response@^1.0.1: 1130 | version "1.0.1" 1131 | resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" 1132 | integrity sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ== 1133 | 1134 | minimatch@^3.0.4: 1135 | version "3.0.4" 1136 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" 1137 | integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== 1138 | dependencies: 1139 | brace-expansion "^1.1.7" 1140 | 1141 | minimist@^1.2.0, minimist@^1.2.5: 1142 | version "1.2.5" 1143 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" 1144 | integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== 1145 | 1146 | mkdirp@~0.5.0: 1147 | version "0.5.5" 1148 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz#d91cefd62d1436ca0f41620e251288d420099def" 1149 | integrity sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ== 1150 | dependencies: 1151 | minimist "^1.2.5" 1152 | 1153 | morgan@~1.9.1: 1154 | version "1.9.1" 1155 | resolved "https://registry.yarnpkg.com/morgan/-/morgan-1.9.1.tgz#0a8d16734a1d9afbc824b99df87e738e58e2da59" 1156 | integrity sha512-HQStPIV4y3afTiCYVxirakhlCfGkI161c76kKFca7Fk1JusM//Qeo1ej2XaMniiNeaZklMVrh3vTtIzpzwbpmA== 1157 | dependencies: 1158 | basic-auth "~2.0.0" 1159 | debug "2.6.9" 1160 | depd "~1.1.2" 1161 | on-finished "~2.3.0" 1162 | on-headers "~1.0.1" 1163 | 1164 | ms@2.0.0: 1165 | version "2.0.0" 1166 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" 1167 | integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= 1168 | 1169 | ms@2.1.2: 1170 | version "2.1.2" 1171 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" 1172 | integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== 1173 | 1174 | ms@^2.1.1: 1175 | version "2.1.3" 1176 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" 1177 | integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== 1178 | 1179 | negotiator@0.6.2: 1180 | version "0.6.2" 1181 | resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.2.tgz#feacf7ccf525a77ae9634436a64883ffeca346fb" 1182 | integrity sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw== 1183 | 1184 | nodemon@^2.0.9: 1185 | version "2.0.9" 1186 | resolved "https://registry.yarnpkg.com/nodemon/-/nodemon-2.0.9.tgz#f5cd550ba215da3c1081459ae2c1c8da2c353165" 1187 | integrity sha512-6O4k7C8f2HQArGpaPBOqGGddjzDLQAqCYmq3tKMeNIbz7Is/hOphMHy2dcY10sSq5wl3cqyn9Iz+Ep2j51JOLg== 1188 | dependencies: 1189 | chokidar "^3.2.2" 1190 | debug "^3.2.6" 1191 | ignore-by-default "^1.0.1" 1192 | minimatch "^3.0.4" 1193 | pstree.remy "^1.1.7" 1194 | semver "^5.7.1" 1195 | supports-color "^5.5.0" 1196 | touch "^3.1.0" 1197 | undefsafe "^2.0.3" 1198 | update-notifier "^4.1.0" 1199 | 1200 | nopt@~1.0.10: 1201 | version "1.0.10" 1202 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-1.0.10.tgz#6ddd21bd2a31417b92727dd585f8a6f37608ebee" 1203 | integrity sha1-bd0hvSoxQXuScn3Vhfim83YI6+4= 1204 | dependencies: 1205 | abbrev "1" 1206 | 1207 | normalize-path@^3.0.0, normalize-path@~3.0.0: 1208 | version "3.0.0" 1209 | resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" 1210 | integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== 1211 | 1212 | normalize-url@^4.1.0: 1213 | version "4.5.1" 1214 | resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.1.tgz#0dd90cf1288ee1d1313b87081c9a5932ee48518a" 1215 | integrity sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA== 1216 | 1217 | object-assign@^4: 1218 | version "4.1.1" 1219 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 1220 | integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= 1221 | 1222 | on-finished@~2.3.0: 1223 | version "2.3.0" 1224 | resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" 1225 | integrity sha1-IPEzZIGwg811M3mSoWlxqi2QaUc= 1226 | dependencies: 1227 | ee-first "1.1.1" 1228 | 1229 | on-headers@~1.0.1: 1230 | version "1.0.2" 1231 | resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.2.tgz#772b0ae6aaa525c399e489adfad90c403eb3c28f" 1232 | integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== 1233 | 1234 | once@^1.3.0, once@^1.3.1, once@^1.4.0: 1235 | version "1.4.0" 1236 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 1237 | integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= 1238 | dependencies: 1239 | wrappy "1" 1240 | 1241 | optimist@~0.3.5: 1242 | version "0.3.7" 1243 | resolved "https://registry.yarnpkg.com/optimist/-/optimist-0.3.7.tgz#c90941ad59e4273328923074d2cf2e7cbc6ec0d9" 1244 | integrity sha1-yQlBrVnkJzMokjB00s8ufLxuwNk= 1245 | dependencies: 1246 | wordwrap "~0.0.2" 1247 | 1248 | p-cancelable@^1.0.0: 1249 | version "1.1.0" 1250 | resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-1.1.0.tgz#d078d15a3af409220c886f1d9a0ca2e441ab26cc" 1251 | integrity sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw== 1252 | 1253 | package-json@^6.3.0: 1254 | version "6.5.0" 1255 | resolved "https://registry.yarnpkg.com/package-json/-/package-json-6.5.0.tgz#6feedaca35e75725876d0b0e64974697fed145b0" 1256 | integrity sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ== 1257 | dependencies: 1258 | got "^9.6.0" 1259 | registry-auth-token "^4.0.0" 1260 | registry-url "^5.0.0" 1261 | semver "^6.2.0" 1262 | 1263 | parseqs@0.0.6: 1264 | version "0.0.6" 1265 | resolved "https://registry.yarnpkg.com/parseqs/-/parseqs-0.0.6.tgz#8e4bb5a19d1cdc844a08ac974d34e273afa670d5" 1266 | integrity sha512-jeAGzMDbfSHHA091hr0r31eYfTig+29g3GKKE/PPbEQ65X0lmMwlEoqmhzu0iztID5uJpZsFlUPDP8ThPL7M8w== 1267 | 1268 | parseuri@0.0.6: 1269 | version "0.0.6" 1270 | resolved "https://registry.yarnpkg.com/parseuri/-/parseuri-0.0.6.tgz#e1496e829e3ac2ff47f39a4dd044b32823c4a25a" 1271 | integrity sha512-AUjen8sAkGgao7UyCX6Ahv0gIK2fABKmYjvP4xmy5JaKvcbTRueIqIPHLAfq30xJddqSE033IOMUSOMCcK3Sow== 1272 | 1273 | parseurl@~1.3.2: 1274 | version "1.3.3" 1275 | resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" 1276 | integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== 1277 | 1278 | path-is-absolute@^1.0.0: 1279 | version "1.0.1" 1280 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 1281 | integrity sha1-F0uSaHNVNP+8es5r9TpanhtcX18= 1282 | 1283 | path-to-regexp@0.1.7: 1284 | version "0.1.7" 1285 | resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" 1286 | integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= 1287 | 1288 | path-to-regexp@^3.0.0: 1289 | version "3.2.0" 1290 | resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-3.2.0.tgz#fa7877ecbc495c601907562222453c43cc204a5f" 1291 | integrity sha512-jczvQbCUS7XmS7o+y1aEO9OBVFeZBQ1MDSEqmO7xSoPgOPoowY/SxLpZ6Vh97/8qHZOteiCKb7gkG9gA2ZUxJA== 1292 | 1293 | picomatch@^2.0.4, picomatch@^2.2.1: 1294 | version "2.3.0" 1295 | resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.0.tgz#f1f061de8f6a4bf022892e2d128234fb98302972" 1296 | integrity sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw== 1297 | 1298 | prepend-http@^2.0.0: 1299 | version "2.0.0" 1300 | resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-2.0.0.tgz#e92434bfa5ea8c19f41cdfd401d741a3c819d897" 1301 | integrity sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc= 1302 | 1303 | promise@^6.0.1: 1304 | version "6.1.0" 1305 | resolved "https://registry.yarnpkg.com/promise/-/promise-6.1.0.tgz#2ce729f6b94b45c26891ad0602c5c90e04c6eef6" 1306 | integrity sha1-LOcp9rlLRcJoka0GAsXJDgTG7vY= 1307 | dependencies: 1308 | asap "~1.0.0" 1309 | 1310 | promise@~2.0: 1311 | version "2.0.0" 1312 | resolved "https://registry.yarnpkg.com/promise/-/promise-2.0.0.tgz#46648aa9d605af5d2e70c3024bf59436da02b80e" 1313 | integrity sha1-RmSKqdYFr10ucMMCS/WUNtoCuA4= 1314 | dependencies: 1315 | is-promise "~1" 1316 | 1317 | proxy-addr@~2.0.4: 1318 | version "2.0.7" 1319 | resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" 1320 | integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== 1321 | dependencies: 1322 | forwarded "0.2.0" 1323 | ipaddr.js "1.9.1" 1324 | 1325 | pstree.remy@^1.1.7: 1326 | version "1.1.8" 1327 | resolved "https://registry.yarnpkg.com/pstree.remy/-/pstree.remy-1.1.8.tgz#c242224f4a67c21f686839bbdb4ac282b8373d3a" 1328 | integrity sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w== 1329 | 1330 | pump@^3.0.0: 1331 | version "3.0.0" 1332 | resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" 1333 | integrity sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww== 1334 | dependencies: 1335 | end-of-stream "^1.1.0" 1336 | once "^1.3.1" 1337 | 1338 | pupa@^2.0.1: 1339 | version "2.1.1" 1340 | resolved "https://registry.yarnpkg.com/pupa/-/pupa-2.1.1.tgz#f5e8fd4afc2c5d97828faa523549ed8744a20d62" 1341 | integrity sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A== 1342 | dependencies: 1343 | escape-goat "^2.0.0" 1344 | 1345 | qs@6.5.2: 1346 | version "6.5.2" 1347 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.2.tgz#cb3ae806e8740444584ef154ce8ee98d403f3e36" 1348 | integrity sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA== 1349 | 1350 | range-parser@~1.2.0: 1351 | version "1.2.1" 1352 | resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" 1353 | integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== 1354 | 1355 | raw-body@2.3.3: 1356 | version "2.3.3" 1357 | resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.3.3.tgz#1b324ece6b5706e153855bc1148c65bb7f6ea0c3" 1358 | integrity sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw== 1359 | dependencies: 1360 | bytes "3.0.0" 1361 | http-errors "1.6.3" 1362 | iconv-lite "0.4.23" 1363 | unpipe "1.0.0" 1364 | 1365 | rc@^1.2.8: 1366 | version "1.2.8" 1367 | resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" 1368 | integrity sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw== 1369 | dependencies: 1370 | deep-extend "^0.6.0" 1371 | ini "~1.3.0" 1372 | minimist "^1.2.0" 1373 | strip-json-comments "~2.0.1" 1374 | 1375 | readdirp@~3.6.0: 1376 | version "3.6.0" 1377 | resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" 1378 | integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== 1379 | dependencies: 1380 | picomatch "^2.2.1" 1381 | 1382 | reflect-metadata@^0.1.10, reflect-metadata@^0.1.13: 1383 | version "0.1.13" 1384 | resolved "https://registry.yarnpkg.com/reflect-metadata/-/reflect-metadata-0.1.13.tgz#67ae3ca57c972a2aa1642b10fe363fe32d49dc08" 1385 | integrity sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg== 1386 | 1387 | registry-auth-token@^4.0.0: 1388 | version "4.2.1" 1389 | resolved "https://registry.yarnpkg.com/registry-auth-token/-/registry-auth-token-4.2.1.tgz#6d7b4006441918972ccd5fedcd41dc322c79b250" 1390 | integrity sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw== 1391 | dependencies: 1392 | rc "^1.2.8" 1393 | 1394 | registry-url@^5.0.0: 1395 | version "5.1.0" 1396 | resolved "https://registry.yarnpkg.com/registry-url/-/registry-url-5.1.0.tgz#e98334b50d5434b81136b44ec638d9c2009c5009" 1397 | integrity sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw== 1398 | dependencies: 1399 | rc "^1.2.8" 1400 | 1401 | repeat-string@^1.5.2: 1402 | version "1.6.1" 1403 | resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" 1404 | integrity sha1-jcrkcOHIirwtYA//Sndihtp15jc= 1405 | 1406 | responselike@^1.0.2: 1407 | version "1.0.2" 1408 | resolved "https://registry.yarnpkg.com/responselike/-/responselike-1.0.2.tgz#918720ef3b631c5642be068f15ade5a46f4ba1e7" 1409 | integrity sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec= 1410 | dependencies: 1411 | lowercase-keys "^1.0.0" 1412 | 1413 | right-align@^0.1.1: 1414 | version "0.1.3" 1415 | resolved "https://registry.yarnpkg.com/right-align/-/right-align-0.1.3.tgz#61339b722fe6a3515689210d24e14c96148613ef" 1416 | integrity sha1-YTObci/mo1FWiSENJOFMlhSGE+8= 1417 | dependencies: 1418 | align-text "^0.1.1" 1419 | 1420 | safe-buffer@5.1.2: 1421 | version "5.1.2" 1422 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" 1423 | integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== 1424 | 1425 | "safer-buffer@>= 2.1.2 < 3": 1426 | version "2.1.2" 1427 | resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" 1428 | integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== 1429 | 1430 | semver-diff@^3.1.1: 1431 | version "3.1.1" 1432 | resolved "https://registry.yarnpkg.com/semver-diff/-/semver-diff-3.1.1.tgz#05f77ce59f325e00e2706afd67bb506ddb1ca32b" 1433 | integrity sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg== 1434 | dependencies: 1435 | semver "^6.3.0" 1436 | 1437 | semver@^5.7.1: 1438 | version "5.7.1" 1439 | resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" 1440 | integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== 1441 | 1442 | semver@^6.0.0, semver@^6.2.0, semver@^6.3.0: 1443 | version "6.3.0" 1444 | resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" 1445 | integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== 1446 | 1447 | send@0.16.2: 1448 | version "0.16.2" 1449 | resolved "https://registry.yarnpkg.com/send/-/send-0.16.2.tgz#6ecca1e0f8c156d141597559848df64730a6bbc1" 1450 | integrity sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw== 1451 | dependencies: 1452 | debug "2.6.9" 1453 | depd "~1.1.2" 1454 | destroy "~1.0.4" 1455 | encodeurl "~1.0.2" 1456 | escape-html "~1.0.3" 1457 | etag "~1.8.1" 1458 | fresh "0.5.2" 1459 | http-errors "~1.6.2" 1460 | mime "1.4.1" 1461 | ms "2.0.0" 1462 | on-finished "~2.3.0" 1463 | range-parser "~1.2.0" 1464 | statuses "~1.4.0" 1465 | 1466 | serve-static@1.13.2: 1467 | version "1.13.2" 1468 | resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.13.2.tgz#095e8472fd5b46237db50ce486a43f4b86c6cec1" 1469 | integrity sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw== 1470 | dependencies: 1471 | encodeurl "~1.0.2" 1472 | escape-html "~1.0.3" 1473 | parseurl "~1.3.2" 1474 | send "0.16.2" 1475 | 1476 | setprototypeof@1.1.0: 1477 | version "1.1.0" 1478 | resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.0.tgz#d0bd85536887b6fe7c0d818cb962d9d91c54e656" 1479 | integrity sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ== 1480 | 1481 | signal-exit@^3.0.2: 1482 | version "3.0.3" 1483 | resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz#a1410c2edd8f077b08b4e253c8eacfcaf057461c" 1484 | integrity sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA== 1485 | 1486 | socket-controllers@^0.0.5: 1487 | version "0.0.5" 1488 | resolved "https://registry.yarnpkg.com/socket-controllers/-/socket-controllers-0.0.5.tgz#31da62171d86aafb0a407197033258542831eaa0" 1489 | integrity sha512-E1RrNVaIlJ3f5gPM5s6RIcyva6u24aLGrbKCwos/jX3vrdGBiqrUMdOo6Y8K9cumiBt8oUGlijFetOQcV016wg== 1490 | dependencies: 1491 | class-transformer "^0.1.6" 1492 | path-to-regexp "^3.0.0" 1493 | reflect-metadata "^0.1.10" 1494 | socket.io "^2.0.1" 1495 | 1496 | socket.io-adapter@~1.1.0: 1497 | version "1.1.2" 1498 | resolved "https://registry.yarnpkg.com/socket.io-adapter/-/socket.io-adapter-1.1.2.tgz#ab3f0d6f66b8fc7fca3959ab5991f82221789be9" 1499 | integrity sha512-WzZRUj1kUjrTIrUKpZLEzFZ1OLj5FwLlAFQs9kuZJzJi5DKdU7FsWc36SNmA8iDOtwBQyT8FkrriRM8vXLYz8g== 1500 | 1501 | socket.io-adapter@~2.3.0: 1502 | version "2.3.1" 1503 | resolved "https://registry.yarnpkg.com/socket.io-adapter/-/socket.io-adapter-2.3.1.tgz#a442720cb09a4823cfb81287dda1f9b52d4ccdb2" 1504 | integrity sha512-8cVkRxI8Nt2wadkY6u60Y4rpW3ejA1rxgcK2JuyIhmF+RMNpTy1QRtkHIDUOf3B4HlQwakMsWbKftMv/71VMmw== 1505 | 1506 | socket.io-client@2.4.0: 1507 | version "2.4.0" 1508 | resolved "https://registry.yarnpkg.com/socket.io-client/-/socket.io-client-2.4.0.tgz#aafb5d594a3c55a34355562fc8aea22ed9119a35" 1509 | integrity sha512-M6xhnKQHuuZd4Ba9vltCLT9oa+YvTsP8j9NcEiLElfIg8KeYPyhWOes6x4t+LTAC8enQbE/995AdTem2uNyKKQ== 1510 | dependencies: 1511 | backo2 "1.0.2" 1512 | component-bind "1.0.0" 1513 | component-emitter "~1.3.0" 1514 | debug "~3.1.0" 1515 | engine.io-client "~3.5.0" 1516 | has-binary2 "~1.0.2" 1517 | indexof "0.0.1" 1518 | parseqs "0.0.6" 1519 | parseuri "0.0.6" 1520 | socket.io-parser "~3.3.0" 1521 | to-array "0.1.4" 1522 | 1523 | socket.io-parser@~3.3.0: 1524 | version "3.3.2" 1525 | resolved "https://registry.yarnpkg.com/socket.io-parser/-/socket.io-parser-3.3.2.tgz#ef872009d0adcf704f2fbe830191a14752ad50b6" 1526 | integrity sha512-FJvDBuOALxdCI9qwRrO/Rfp9yfndRtc1jSgVgV8FDraihmSP/MLGD5PEuJrNfjALvcQ+vMDM/33AWOYP/JSjDg== 1527 | dependencies: 1528 | component-emitter "~1.3.0" 1529 | debug "~3.1.0" 1530 | isarray "2.0.1" 1531 | 1532 | socket.io-parser@~3.4.0: 1533 | version "3.4.1" 1534 | resolved "https://registry.yarnpkg.com/socket.io-parser/-/socket.io-parser-3.4.1.tgz#b06af838302975837eab2dc980037da24054d64a" 1535 | integrity sha512-11hMgzL+WCLWf1uFtHSNvliI++tcRUWdoeYuwIl+Axvwy9z2gQM+7nJyN3STj1tLj5JyIUH8/gpDGxzAlDdi0A== 1536 | dependencies: 1537 | component-emitter "1.2.1" 1538 | debug "~4.1.0" 1539 | isarray "2.0.1" 1540 | 1541 | socket.io-parser@~4.0.3: 1542 | version "4.0.4" 1543 | resolved "https://registry.yarnpkg.com/socket.io-parser/-/socket.io-parser-4.0.4.tgz#9ea21b0d61508d18196ef04a2c6b9ab630f4c2b0" 1544 | integrity sha512-t+b0SS+IxG7Rxzda2EVvyBZbvFPBCjJoyHuE0P//7OAsN23GItzDRdWa6ALxZI/8R5ygK7jAR6t028/z+7295g== 1545 | dependencies: 1546 | "@types/component-emitter" "^1.2.10" 1547 | component-emitter "~1.3.0" 1548 | debug "~4.3.1" 1549 | 1550 | socket.io@^2.0.1: 1551 | version "2.4.1" 1552 | resolved "https://registry.yarnpkg.com/socket.io/-/socket.io-2.4.1.tgz#95ad861c9a52369d7f1a68acf0d4a1b16da451d2" 1553 | integrity sha512-Si18v0mMXGAqLqCVpTxBa8MGqriHGQh8ccEOhmsmNS3thNCGBwO8WGrwMibANsWtQQ5NStdZwHqZR3naJVFc3w== 1554 | dependencies: 1555 | debug "~4.1.0" 1556 | engine.io "~3.5.0" 1557 | has-binary2 "~1.0.2" 1558 | socket.io-adapter "~1.1.0" 1559 | socket.io-client "2.4.0" 1560 | socket.io-parser "~3.4.0" 1561 | 1562 | socket.io@^4.1.2: 1563 | version "4.1.2" 1564 | resolved "https://registry.yarnpkg.com/socket.io/-/socket.io-4.1.2.tgz#f90f9002a8d550efe2aa1d320deebb9a45b83233" 1565 | integrity sha512-xK0SD1C7hFrh9+bYoYCdVt+ncixkSLKtNLCax5aEy1o3r5PaO5yQhVb97exIe67cE7lAK+EpyMytXWTWmyZY8w== 1566 | dependencies: 1567 | "@types/cookie" "^0.4.0" 1568 | "@types/cors" "^2.8.8" 1569 | "@types/node" ">=10.0.0" 1570 | accepts "~1.3.4" 1571 | base64id "~2.0.0" 1572 | debug "~4.3.1" 1573 | engine.io "~5.1.0" 1574 | socket.io-adapter "~2.3.0" 1575 | socket.io-parser "~4.0.3" 1576 | 1577 | source-map-support@^0.5.17: 1578 | version "0.5.19" 1579 | resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.19.tgz#a98b62f86dcaf4f67399648c085291ab9e8fed61" 1580 | integrity sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw== 1581 | dependencies: 1582 | buffer-from "^1.0.0" 1583 | source-map "^0.6.0" 1584 | 1585 | source-map@0.4.x: 1586 | version "0.4.4" 1587 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.4.4.tgz#eba4f5da9c0dc999de68032d8b4f76173652036b" 1588 | integrity sha1-66T12pwNyZneaAMti092FzZSA2s= 1589 | dependencies: 1590 | amdefine ">=0.0.4" 1591 | 1592 | source-map@^0.6.0: 1593 | version "0.6.1" 1594 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" 1595 | integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== 1596 | 1597 | source-map@~0.1.7: 1598 | version "0.1.43" 1599 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.1.43.tgz#c24bc146ca517c1471f5dacbe2571b2b7f9e3346" 1600 | integrity sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y= 1601 | dependencies: 1602 | amdefine ">=0.0.4" 1603 | 1604 | source-map@~0.5.1: 1605 | version "0.5.7" 1606 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" 1607 | integrity sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w= 1608 | 1609 | "statuses@>= 1.4.0 < 2": 1610 | version "1.5.0" 1611 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" 1612 | integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= 1613 | 1614 | statuses@~1.4.0: 1615 | version "1.4.0" 1616 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.4.0.tgz#bb73d446da2796106efcc1b601a253d6c46bd087" 1617 | integrity sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew== 1618 | 1619 | string-width@^3.0.0: 1620 | version "3.1.0" 1621 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz#22767be21b62af1081574306f69ac51b62203961" 1622 | integrity sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w== 1623 | dependencies: 1624 | emoji-regex "^7.0.1" 1625 | is-fullwidth-code-point "^2.0.0" 1626 | strip-ansi "^5.1.0" 1627 | 1628 | string-width@^4.0.0, string-width@^4.1.0: 1629 | version "4.2.2" 1630 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.2.tgz#dafd4f9559a7585cfba529c6a0a4f73488ebd4c5" 1631 | integrity sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA== 1632 | dependencies: 1633 | emoji-regex "^8.0.0" 1634 | is-fullwidth-code-point "^3.0.0" 1635 | strip-ansi "^6.0.0" 1636 | 1637 | strip-ansi@^5.1.0: 1638 | version "5.2.0" 1639 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" 1640 | integrity sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA== 1641 | dependencies: 1642 | ansi-regex "^4.1.0" 1643 | 1644 | strip-ansi@^6.0.0: 1645 | version "6.0.0" 1646 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" 1647 | integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w== 1648 | dependencies: 1649 | ansi-regex "^5.0.0" 1650 | 1651 | strip-json-comments@~2.0.1: 1652 | version "2.0.1" 1653 | resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" 1654 | integrity sha1-PFMZQukIwml8DsNEhYwobHygpgo= 1655 | 1656 | supports-color@^5.5.0: 1657 | version "5.5.0" 1658 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" 1659 | integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== 1660 | dependencies: 1661 | has-flag "^3.0.0" 1662 | 1663 | supports-color@^7.1.0: 1664 | version "7.2.0" 1665 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" 1666 | integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== 1667 | dependencies: 1668 | has-flag "^4.0.0" 1669 | 1670 | term-size@^2.1.0: 1671 | version "2.2.1" 1672 | resolved "https://registry.yarnpkg.com/term-size/-/term-size-2.2.1.tgz#2a6a54840432c2fb6320fea0f415531e90189f54" 1673 | integrity sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg== 1674 | 1675 | to-array@0.1.4: 1676 | version "0.1.4" 1677 | resolved "https://registry.yarnpkg.com/to-array/-/to-array-0.1.4.tgz#17e6c11f73dd4f3d74cda7a4ff3238e9ad9bf890" 1678 | integrity sha1-F+bBH3PdTz10zaek/zI46a2b+JA= 1679 | 1680 | to-readable-stream@^1.0.0: 1681 | version "1.0.0" 1682 | resolved "https://registry.yarnpkg.com/to-readable-stream/-/to-readable-stream-1.0.0.tgz#ce0aa0c2f3df6adf852efb404a783e77c0475771" 1683 | integrity sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q== 1684 | 1685 | to-regex-range@^5.0.1: 1686 | version "5.0.1" 1687 | resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" 1688 | integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== 1689 | dependencies: 1690 | is-number "^7.0.0" 1691 | 1692 | touch@^3.1.0: 1693 | version "3.1.0" 1694 | resolved "https://registry.yarnpkg.com/touch/-/touch-3.1.0.tgz#fe365f5f75ec9ed4e56825e0bb76d24ab74af83b" 1695 | integrity sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA== 1696 | dependencies: 1697 | nopt "~1.0.10" 1698 | 1699 | transformers@2.1.0: 1700 | version "2.1.0" 1701 | resolved "https://registry.yarnpkg.com/transformers/-/transformers-2.1.0.tgz#5d23cb35561dd85dc67fb8482309b47d53cce9a7" 1702 | integrity sha1-XSPLNVYd2F3Gf7hIIwm0fVPM6ac= 1703 | dependencies: 1704 | css "~1.0.8" 1705 | promise "~2.0" 1706 | uglify-js "~2.2.5" 1707 | 1708 | ts-node@^10.0.0: 1709 | version "10.0.0" 1710 | resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-10.0.0.tgz#05f10b9a716b0b624129ad44f0ea05dac84ba3be" 1711 | integrity sha512-ROWeOIUvfFbPZkoDis0L/55Fk+6gFQNZwwKPLinacRl6tsxstTF1DbAcLKkovwnpKMVvOMHP1TIbnwXwtLg1gg== 1712 | dependencies: 1713 | "@tsconfig/node10" "^1.0.7" 1714 | "@tsconfig/node12" "^1.0.7" 1715 | "@tsconfig/node14" "^1.0.0" 1716 | "@tsconfig/node16" "^1.0.1" 1717 | arg "^4.1.0" 1718 | create-require "^1.1.0" 1719 | diff "^4.0.1" 1720 | make-error "^1.1.1" 1721 | source-map-support "^0.5.17" 1722 | yn "3.1.1" 1723 | 1724 | type-fest@^0.8.1: 1725 | version "0.8.1" 1726 | resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" 1727 | integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== 1728 | 1729 | type-is@~1.6.16: 1730 | version "1.6.18" 1731 | resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" 1732 | integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== 1733 | dependencies: 1734 | media-typer "0.3.0" 1735 | mime-types "~2.1.24" 1736 | 1737 | typedarray-to-buffer@^3.1.5: 1738 | version "3.1.5" 1739 | resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" 1740 | integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== 1741 | dependencies: 1742 | is-typedarray "^1.0.0" 1743 | 1744 | typescript@^4.3.5: 1745 | version "4.3.5" 1746 | resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.3.5.tgz#4d1c37cc16e893973c45a06886b7113234f119f4" 1747 | integrity sha512-DqQgihaQ9cUrskJo9kIyW/+g0Vxsk8cDtZ52a3NGh0YNTfpUSArXSohyUGnvbPazEPLu398C0UxmKSOrPumUzA== 1748 | 1749 | uglify-js@^2.4.19: 1750 | version "2.8.29" 1751 | resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.8.29.tgz#29c5733148057bb4e1f75df35b7a9cb72e6a59dd" 1752 | integrity sha1-KcVzMUgFe7Th913zW3qcty5qWd0= 1753 | dependencies: 1754 | source-map "~0.5.1" 1755 | yargs "~3.10.0" 1756 | optionalDependencies: 1757 | uglify-to-browserify "~1.0.0" 1758 | 1759 | uglify-js@~2.2.5: 1760 | version "2.2.5" 1761 | resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.2.5.tgz#a6e02a70d839792b9780488b7b8b184c095c99c7" 1762 | integrity sha1-puAqcNg5eSuXgEiLe4sYTAlcmcc= 1763 | dependencies: 1764 | optimist "~0.3.5" 1765 | source-map "~0.1.7" 1766 | 1767 | uglify-to-browserify@~1.0.0: 1768 | version "1.0.2" 1769 | resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7" 1770 | integrity sha1-bgkk1r2mta/jSeOabWMoUKD4grc= 1771 | 1772 | undefsafe@^2.0.3: 1773 | version "2.0.3" 1774 | resolved "https://registry.yarnpkg.com/undefsafe/-/undefsafe-2.0.3.tgz#6b166e7094ad46313b2202da7ecc2cd7cc6e7aae" 1775 | integrity sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A== 1776 | dependencies: 1777 | debug "^2.2.0" 1778 | 1779 | unique-string@^2.0.0: 1780 | version "2.0.0" 1781 | resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-2.0.0.tgz#39c6451f81afb2749de2b233e3f7c5e8843bd89d" 1782 | integrity sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg== 1783 | dependencies: 1784 | crypto-random-string "^2.0.0" 1785 | 1786 | unpipe@1.0.0, unpipe@~1.0.0: 1787 | version "1.0.0" 1788 | resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" 1789 | integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= 1790 | 1791 | update-notifier@^4.1.0: 1792 | version "4.1.3" 1793 | resolved "https://registry.yarnpkg.com/update-notifier/-/update-notifier-4.1.3.tgz#be86ee13e8ce48fb50043ff72057b5bd598e1ea3" 1794 | integrity sha512-Yld6Z0RyCYGB6ckIjffGOSOmHXj1gMeE7aROz4MG+XMkmixBX4jUngrGXNYz7wPKBmtoD4MnBa2Anu7RSKht/A== 1795 | dependencies: 1796 | boxen "^4.2.0" 1797 | chalk "^3.0.0" 1798 | configstore "^5.0.1" 1799 | has-yarn "^2.1.0" 1800 | import-lazy "^2.1.0" 1801 | is-ci "^2.0.0" 1802 | is-installed-globally "^0.3.1" 1803 | is-npm "^4.0.0" 1804 | is-yarn-global "^0.3.0" 1805 | latest-version "^5.0.0" 1806 | pupa "^2.0.1" 1807 | semver-diff "^3.1.1" 1808 | xdg-basedir "^4.0.0" 1809 | 1810 | url-parse-lax@^3.0.0: 1811 | version "3.0.0" 1812 | resolved "https://registry.yarnpkg.com/url-parse-lax/-/url-parse-lax-3.0.0.tgz#16b5cafc07dbe3676c1b1999177823d6503acb0c" 1813 | integrity sha1-FrXK/Afb42dsGxmZF3gj1lA6yww= 1814 | dependencies: 1815 | prepend-http "^2.0.0" 1816 | 1817 | utils-merge@1.0.1: 1818 | version "1.0.1" 1819 | resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" 1820 | integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= 1821 | 1822 | vary@^1, vary@~1.1.2: 1823 | version "1.1.2" 1824 | resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" 1825 | integrity sha1-IpnwLG3tMNSllhsLn3RSShj2NPw= 1826 | 1827 | void-elements@~2.0.1: 1828 | version "2.0.1" 1829 | resolved "https://registry.yarnpkg.com/void-elements/-/void-elements-2.0.1.tgz#c066afb582bb1cb4128d60ea92392e94d5e9dbec" 1830 | integrity sha1-wGavtYK7HLQSjWDqkjkulNXp2+w= 1831 | 1832 | widest-line@^3.1.0: 1833 | version "3.1.0" 1834 | resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-3.1.0.tgz#8292333bbf66cb45ff0de1603b136b7ae1496eca" 1835 | integrity sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg== 1836 | dependencies: 1837 | string-width "^4.0.0" 1838 | 1839 | window-size@0.1.0: 1840 | version "0.1.0" 1841 | resolved "https://registry.yarnpkg.com/window-size/-/window-size-0.1.0.tgz#5438cd2ea93b202efa3a19fe8887aee7c94f9c9d" 1842 | integrity sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0= 1843 | 1844 | with@~4.0.0: 1845 | version "4.0.3" 1846 | resolved "https://registry.yarnpkg.com/with/-/with-4.0.3.tgz#eefd154e9e79d2c8d3417b647a8f14d9fecce14e" 1847 | integrity sha1-7v0VTp550sjTQXtkeo8U2f7M4U4= 1848 | dependencies: 1849 | acorn "^1.0.1" 1850 | acorn-globals "^1.0.3" 1851 | 1852 | wordwrap@0.0.2: 1853 | version "0.0.2" 1854 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.2.tgz#b79669bb42ecb409f83d583cad52ca17eaa1643f" 1855 | integrity sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8= 1856 | 1857 | wordwrap@~0.0.2: 1858 | version "0.0.3" 1859 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.3.tgz#a3d5da6cd5c0bc0008d37234bbaf1bed63059107" 1860 | integrity sha1-o9XabNXAvAAI03I0u68b7WMFkQc= 1861 | 1862 | wrappy@1: 1863 | version "1.0.2" 1864 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 1865 | integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= 1866 | 1867 | write-file-atomic@^3.0.0: 1868 | version "3.0.3" 1869 | resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" 1870 | integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== 1871 | dependencies: 1872 | imurmurhash "^0.1.4" 1873 | is-typedarray "^1.0.0" 1874 | signal-exit "^3.0.2" 1875 | typedarray-to-buffer "^3.1.5" 1876 | 1877 | ws@~7.4.2: 1878 | version "7.4.6" 1879 | resolved "https://registry.yarnpkg.com/ws/-/ws-7.4.6.tgz#5654ca8ecdeee47c33a9a4bf6d28e2be2980377c" 1880 | integrity sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A== 1881 | 1882 | xdg-basedir@^4.0.0: 1883 | version "4.0.0" 1884 | resolved "https://registry.yarnpkg.com/xdg-basedir/-/xdg-basedir-4.0.0.tgz#4bc8d9984403696225ef83a1573cbbcb4e79db13" 1885 | integrity sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q== 1886 | 1887 | xmlhttprequest-ssl@~1.6.2: 1888 | version "1.6.3" 1889 | resolved "https://registry.yarnpkg.com/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.6.3.tgz#03b713873b01659dfa2c1c5d056065b27ddc2de6" 1890 | integrity sha512-3XfeQE/wNkvrIktn2Kf0869fC0BN6UpydVasGIeSm2B1Llihf7/0UfZM+eCkOw3P7bP4+qPgqhm7ZoxuJtFU0Q== 1891 | 1892 | yargs@~3.10.0: 1893 | version "3.10.0" 1894 | resolved "https://registry.yarnpkg.com/yargs/-/yargs-3.10.0.tgz#f7ee7bd857dd7c1d2d38c0e74efbd681d1431fd1" 1895 | integrity sha1-9+572FfdfB0tOMDnTvvWgdFDH9E= 1896 | dependencies: 1897 | camelcase "^1.0.2" 1898 | cliui "^2.1.0" 1899 | decamelize "^1.0.0" 1900 | window-size "0.1.0" 1901 | 1902 | yeast@0.1.2: 1903 | version "0.1.2" 1904 | resolved "https://registry.yarnpkg.com/yeast/-/yeast-0.1.2.tgz#008e06d8094320c372dbc2f8ed76a0ca6c8ac419" 1905 | integrity sha1-AI4G2AlDIMNy28L47XagymyKxBk= 1906 | 1907 | yn@3.1.1: 1908 | version "3.1.1" 1909 | resolved "https://registry.yarnpkg.com/yn/-/yn-3.1.1.tgz#1e87401a09d767c1d5eab26a6e4c185182d2eb50" 1910 | integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== 1911 | --------------------------------------------------------------------------------