├── 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 |
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 |
--------------------------------------------------------------------------------