├── test ├── publish │ ├── index.js │ ├── .gitignore │ ├── .npmrc │ ├── package.minimal.json │ └── Readme.md ├── publish-scoped │ ├── index.js │ ├── .gitignore │ ├── .npmrc │ ├── package.minimal.json │ └── Readme.md └── install │ ├── .yarnrc │ ├── .gitignore │ ├── .npmrc │ └── package.json ├── examples ├── .gitignore ├── express-s3 │ ├── s3-website-configuration.json │ ├── package.json │ ├── docker-compose.yml │ ├── Readme.md │ └── express-s3.ts ├── util │ ├── response-decorator.ts │ └── logger.ts ├── express-fileserver │ ├── package.json │ └── express-fileserver.ts └── express-sqlite │ ├── package.json │ └── express-sqlite.ts ├── packages ├── .gitignore ├── .npmignore ├── registry │ ├── index.ts │ ├── Readme.md │ ├── package.json │ ├── models.ts │ └── registry.ts ├── provider-fileserver │ ├── package.json │ ├── Readme.md │ └── provider-fileserver.ts ├── provider-s3 │ ├── package.json │ ├── Readme.md │ └── provider-s3.ts ├── provider-sqlite │ ├── package.json │ ├── Readme.md │ └── provider-sqlite.ts └── express-router │ ├── package.json │ ├── Readme.md │ └── router.ts ├── .gitignore ├── .editorconfig ├── nodemon.json ├── .eslintrc.js ├── makefile ├── package.json ├── test.sh ├── README.md ├── tsconfig.json └── yarn.lock /test/publish/index.js: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /test/publish-scoped/index.js: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /examples/.gitignore: -------------------------------------------------------------------------------- 1 | **/*.js 2 | -------------------------------------------------------------------------------- /packages/.gitignore: -------------------------------------------------------------------------------- 1 | **/*.js 2 | -------------------------------------------------------------------------------- /test/install/.yarnrc: -------------------------------------------------------------------------------- 1 | cache-folder "../../.local/.yarn" 2 | -------------------------------------------------------------------------------- /test/publish/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | package.json 3 | -------------------------------------------------------------------------------- /test/publish/.npmrc: -------------------------------------------------------------------------------- 1 | registry = http://127.0.0.1:3000/ 2 | -------------------------------------------------------------------------------- /packages/.npmignore: -------------------------------------------------------------------------------- 1 | **/*.ts 2 | !**/*.d.ts 3 | **/*.map 4 | -------------------------------------------------------------------------------- /test/publish-scoped/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | package.json 3 | -------------------------------------------------------------------------------- /test/publish-scoped/.npmrc: -------------------------------------------------------------------------------- 1 | registry = http://127.0.0.1:3000/ 2 | -------------------------------------------------------------------------------- /test/install/.gitignore: -------------------------------------------------------------------------------- 1 | package-lock.json 2 | yarn.lock 3 | node_modules 4 | -------------------------------------------------------------------------------- /packages/registry/index.ts: -------------------------------------------------------------------------------- 1 | export * from "./models"; 2 | export * from "./registry"; 3 | -------------------------------------------------------------------------------- /test/install/.npmrc: -------------------------------------------------------------------------------- 1 | registry = http://127.0.0.1:3000/ 2 | cache = ../../.local/.npm 3 | -------------------------------------------------------------------------------- /packages/registry/Readme.md: -------------------------------------------------------------------------------- 1 | # @baggy/registry 2 | 3 | The main registry provider. Expects to get a storage provider passed to manage metadata and artifacts 4 | -------------------------------------------------------------------------------- /test/publish/package.minimal.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "no-scope", 3 | "version": "1.0.0", 4 | "publishConfig": { 5 | "registry": "http://localhost:3000/" 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /test/install/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "dependencies": { 3 | "@local/publish-test": "latest", 4 | "no-scope": "latest", 5 | "npm": "latest", 6 | "yarn": "latest" 7 | } 8 | } 9 | -------------------------------------------------------------------------------- /test/publish-scoped/package.minimal.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@local/publish-test", 3 | "version": "1.0.0", 4 | "publishConfig": { 5 | "registry": "http://localhost:3000/" 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .idea 2 | .vs 3 | .vscode 4 | .DS_STORE 5 | 6 | node_modules 7 | 8 | **/*.d.ts 9 | .local 10 | 11 | *.log 12 | npm-debug.log* 13 | yarn-debug.log* 14 | yarn-error.log* 15 | -------------------------------------------------------------------------------- /packages/registry/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/registry", 3 | "version": "1.0.0", 4 | "description": "Main Registry handler for the baggy project", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy" 7 | } 8 | -------------------------------------------------------------------------------- /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | indent_size = 2 5 | indent_style = space 6 | trim_trailing_whitespace = true 7 | charset = utf-8 8 | end_of_line = lf 9 | tab_width = 4 10 | insert_final_newline = true 11 | max_line_length = 120 12 | 13 | [makefile] 14 | indent_style = tab 15 | -------------------------------------------------------------------------------- /nodemon.json: -------------------------------------------------------------------------------- 1 | { 2 | "delay": 100, 3 | "ignore": ["./.aws/", "./.local/"], 4 | "watch": [ 5 | "packages", 6 | "examples", 7 | "test/express-server", 8 | "test/express-sqlite", 9 | "package.json", 10 | "tsconfig.json", 11 | "yarn.lock" 12 | ], 13 | "ext": "*" 14 | } 15 | -------------------------------------------------------------------------------- /packages/provider-fileserver/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/provider-fileserver", 3 | "version": "1.0.0", 4 | "description": "Fileserver provider for @baggy/registry", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy", 7 | "license": "MIT", 8 | "main": "provider-fileserver", 9 | "peerDependencies": { 10 | "@baggy/registry": "*" 11 | } 12 | } 13 | -------------------------------------------------------------------------------- /packages/provider-s3/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/provider-s3", 3 | "version": "1.0.0", 4 | "description": "AWS S3 provider for @baggy/registry", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy", 7 | "license": "MIT", 8 | "main": "provider-s3", 9 | "dependencies": { 10 | "aws-sdk": "^2.678.0" 11 | }, 12 | "peerDependencies": { 13 | "@baggy/registry": "*" 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /examples/express-s3/s3-website-configuration.json: -------------------------------------------------------------------------------- 1 | { 2 | "ErrorDocument": { 3 | "Key": "error.html" 4 | }, 5 | "IndexDocument": { 6 | "Suffix": "index.html" 7 | }, 8 | "RoutingRules": [ 9 | { 10 | "Condition": { 11 | "HttpErrorCodeReturnedEquals": "403" 12 | }, 13 | "Redirect": { 14 | "HostName": "localhost:3000", 15 | "HttpRedirectCode": "string", 16 | "Protocol": "http" 17 | } 18 | } 19 | ] 20 | } 21 | -------------------------------------------------------------------------------- /examples/util/response-decorator.ts: -------------------------------------------------------------------------------- 1 | import { debug } from "./logger"; 2 | import { ResponseDecorator } from "@baggy/express-router/router"; 3 | 4 | export const responseDecorator: ResponseDecorator = (result, request) => { 5 | let { statusCode, body } = result; // eslint-disable-line prefer-const 6 | if (body instanceof Buffer) { 7 | body = body.toString(); 8 | } 9 | debug(Date.now() + `${request.path.replace(/\//g, "_")}.json`, JSON.stringify({ statusCode, body }, null, 2), true); 10 | return result; 11 | }; 12 | -------------------------------------------------------------------------------- /packages/provider-sqlite/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/provider-sqlite", 3 | "version": "1.0.0", 4 | "description": "SQLite3 provider for @baggy/registry", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy", 7 | "license": "MIT", 8 | "main": "provider-sqlite", 9 | "dependencies": {}, 10 | "devDependencies": { 11 | "@types/sqlite3": "^3.1.6" 12 | }, 13 | "peerDependencies": { 14 | "sqlite3": "^4.1.1", 15 | "@baggy/registry": "*" 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /packages/express-router/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/express-router", 3 | "version": "1.0.0", 4 | "description": "Express router for @baggy/registry", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy", 7 | "license": "MIT", 8 | "main": "router.ts", 9 | "dependencies": { 10 | "body-parser": "^1.19.0", 11 | "express": "^4.17.1" 12 | }, 13 | "devDependencies": { 14 | "@types/express": "^4.17.2" 15 | }, 16 | "peerDependencies": { 17 | "@baggy/registry": "*" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /packages/provider-fileserver/Readme.md: -------------------------------------------------------------------------------- 1 | # @baggy/provider-fileserver 2 | 3 | A storage provider for @baggy/registry. 4 | 5 | Saves everything on the specified path in the local file system. 6 | 7 | `yarn add sqlite3 @baggy/provider-fileserver @baggy/registry` 8 | 9 | ```typescript 10 | import Fileserver from "@baggy/provider-fileserver"; 11 | import { Registry } from "@baggy/registry"; 12 | 13 | const fileserver = new Fileserver("path/to/files"); 14 | const registry = new Registry({ 15 | storage: fileserver, 16 | }); 17 | 18 | // Do something with the registry 19 | ``` 20 | -------------------------------------------------------------------------------- /examples/express-fileserver/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/example-fileserver", 3 | "version": "1.0.0", 4 | "description": "Express + Fileserver implementation for the baggy registry", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy", 7 | "license": "MIT", 8 | "main": "express-fileserver", 9 | "private": true, 10 | "dependencies": { 11 | "@baggy/express-router": "*", 12 | "chalk": "^4.0", 13 | "express": "^4.17.1" 14 | }, 15 | "devDependencies": { 16 | "@types/express": "^4.17.2" 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /examples/express-s3/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/example-express-s3", 3 | "version": "1.0.0", 4 | "description": "Express + Fileserver implementation for the baggy registry", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy", 7 | "license": "MIT", 8 | "main": "express-s3", 9 | "private": true, 10 | "dependencies": { 11 | "@baggy/express-router": "*", 12 | "@baggy/provider-s3": "*", 13 | "chalk": "^4.0", 14 | "express": "^4.17.1", 15 | "aws-sdk": "^2.678.0" 16 | }, 17 | "devDependencies": { 18 | "@types/express": "^4.17.2" 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /examples/express-sqlite/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@baggy/express-sqlite", 3 | "version": "1.0.0", 4 | "description": "Express + SQLite3 implementation for the baggy registry", 5 | "author": "Daniel Schuster ", 6 | "repository": "https://github.com/Tanuel/baggy", 7 | "license": "MIT", 8 | "main": "express-sqlite", 9 | "private": true, 10 | "dependencies": { 11 | "@baggy/express-router": "*", 12 | "chalk": "^4.0", 13 | "express": "^4.17.1", 14 | "sqlite3": "^4.1.1" 15 | }, 16 | "devDependencies": { 17 | "@types/express": "^4.17.2", 18 | "@types/sqlite3": "^3.1.6" 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /packages/provider-sqlite/Readme.md: -------------------------------------------------------------------------------- 1 | # @baggy/provider-sqlite 2 | 3 | A storage provider for @baggy/registry. 4 | 5 | Saves everything in the specified sqlite database. 6 | 7 | `yarn add sqlite3 @baggy/provider-sqlite @baggy/registry` 8 | 9 | ```typescript 10 | import Database from "@baggy/provider-sqlite"; 11 | import sqlite3 from "sqlite3"; 12 | import { Registry } from "@baggy/registry"; 13 | 14 | // set up the storage 15 | const db = new sqlite3.Database("path/to/database"); 16 | const storage = new Database(db); 17 | // create registry 18 | const registry = new Registry({ 19 | storage, 20 | }); 21 | 22 | // Do something with the registry 23 | ``` 24 | -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | parser: "@typescript-eslint/parser", 4 | plugins: ["@typescript-eslint"], 5 | extends: [ 6 | "eslint:recommended", 7 | "plugin:@typescript-eslint/eslint-recommended", 8 | "plugin:@typescript-eslint/recommended", 9 | "prettier/@typescript-eslint", 10 | ], 11 | ignorePatterns: ["node_modules", ".local", "**/*.js"], 12 | rules: { 13 | "@typescript-eslint/no-explicit-any": 0, 14 | "@typescript-eslint/no-inferrable-types": 0, 15 | "@typescript-eslint/no-unused-vars": 2, 16 | "@typescript-eslint/explicit-function-return-type": 2, 17 | "@typescript-eslint/no-namespace": 1, 18 | }, 19 | }; 20 | -------------------------------------------------------------------------------- /examples/express-s3/docker-compose.yml: -------------------------------------------------------------------------------- 1 | version: "2.1" 2 | 3 | services: 4 | localstack: 5 | container_name: "baggy-aws-mock" 6 | image: localstack/localstack 7 | ports: 8 | - "4566-4599:4566-4599" 9 | - "${PORT_WEB_UI-8080}:${PORT_WEB_UI-8080}" 10 | environment: 11 | - SERVICES=s3 12 | - DEBUG=${DEBUG- } 13 | - DATA_DIR=/tmp/localstack/data 14 | - PORT_WEB_UI=${PORT_WEB_UI- } 15 | - LAMBDA_EXECUTOR=${LAMBDA_EXECUTOR- } 16 | - DOCKER_HOST=unix:///var/run/docker.sock 17 | - HOST_TMP_FOLDER=.local/localstack 18 | volumes: 19 | - "${PWD}/.local/localstack:/tmp/localstack" 20 | - "/var/run/docker.sock:/var/run/docker.sock" 21 | -------------------------------------------------------------------------------- /examples/express-s3/Readme.md: -------------------------------------------------------------------------------- 1 | # @baggy/example-express-s3 2 | 3 | An example on how to configure baggy using express and the s3 storage provider 4 | 5 | To run this example, start the s3 mock using localstack. 6 | Requirements: 7 | 8 | - [docker](https://www.docker.com/) 9 | - [docker-compose](https://docs.docker.com/compose/install/) 10 | - [awslocal](https://github.com/localstack/awscli-local) - cli wrapper for awscli for localstack 11 | 12 | ## Start up 13 | 14 | - In the repository root, run `make aws-mock` to start up localstack. 15 | - After localstack is ready, run `make aws-bucket` to create the sample bucket. 16 | - Run `yarn serve-s3` to start up the express server 17 | 18 | Then you can run npm and yarn commands against `registry=http://localhost:3000` 19 | 20 | ## Tear down 21 | 22 | Run `make aws-clean` to shut down the server and remove containers and artifacts 23 | -------------------------------------------------------------------------------- /packages/express-router/Readme.md: -------------------------------------------------------------------------------- 1 | # @baggy/express 2 | 3 | Express router for @baggy/registry 4 | 5 | ```typescript 6 | import express from "express"; 7 | import router from "@baggy/express-router"; 8 | import Fileserver from "@baggy/provider-fileserver"; 9 | import { NpmRegistry } from "@baggy/registry"; 10 | 11 | const app = express(); 12 | 13 | // use a local storage provider 14 | const storage = new Fileserver(".local/artifacts"); 15 | 16 | const registry = new NpmRegistry({ 17 | artifactsUrl: "http://localhost:3000", 18 | storage, 19 | proxy: true, 20 | proxyCache: true, 21 | }); 22 | 23 | // set up your own middleware for logging and error handling 24 | 25 | // enable the @baggy/express router 26 | app.use("/npm", router(registry)); 27 | 28 | app.listen(3000, () => { 29 | console.log("Starting Express NpmRegistry on http://localhost:3000/npm/"); 30 | }); 31 | ``` 32 | -------------------------------------------------------------------------------- /makefile: -------------------------------------------------------------------------------- 1 | .PHONY: bootstrap serve test clean aws-mock aws-bucket 2 | 3 | export EXPRESS_S3_DC_FILE=examples/express-s3/docker-compose.yml 4 | export MOCK_BUCKET=baggy-registry-mock 5 | bootstrap: 6 | yarn install 7 | 8 | serve: 9 | yarn serve 10 | 11 | test: 12 | ./test.sh 13 | 14 | clean: 15 | rm -rf .local 16 | 17 | aws-mock: 18 | mkdir -p .local 19 | docker-compose -f ${EXPRESS_S3_DC_FILE} up 20 | 21 | aws-clean: 22 | docker-compose -f ${EXPRESS_S3_DC_FILE} down 23 | docker-compose -f ${EXPRESS_S3_DC_FILE} rm -f -v 24 | sudo rm -rf .local/localstack 25 | 26 | aws-bucket: 27 | awslocal s3 mb s3://${MOCK_BUCKET} 28 | awslocal s3api put-bucket-acl --bucket ${MOCK_BUCKET} --acl public-read 29 | #TODO: use website-configuration and redirect to server when artifact does not exists to trigger proxy 30 | #awslocal s3api put-bucket-website --bucket ${MOCK_BUCKET} --website-configuration file://examples/express-s3/s3-website-configuration.json 31 | -------------------------------------------------------------------------------- /packages/express-router/router.ts: -------------------------------------------------------------------------------- 1 | import express, { NextFunction, Request, Response } from "express"; 2 | import * as NpmRegistry from "@baggy/registry"; 3 | import bodyParser from "body-parser"; 4 | 5 | export interface ResponseDecorator { 6 | (result: NpmRegistry.Response, req: Request, res: Response, next: NextFunction): NpmRegistry.Response | never; 7 | } 8 | 9 | export default function (registry: NpmRegistry.Registry, responseDecorator?: ResponseDecorator): express.Router { 10 | const router = express.Router(); 11 | 12 | router.use(bodyParser.json({ strict: false, limit: "5mb" })); 13 | router.all("*", async (request: Request, res: Response, next: NextFunction) => { 14 | try { 15 | let result = await registry.handle(request); 16 | if (typeof responseDecorator === "function") { 17 | result = responseDecorator(result, request, res, next); 18 | } 19 | res.statusCode = result.statusCode; 20 | res.send(result.body); 21 | } catch (e) { 22 | next(e); 23 | } 24 | }); 25 | return router; 26 | } 27 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "author": "Daniel Schuster ", 3 | "description": "A reverse engineered NPM registry", 4 | "repository": "https://github.com/Tanuel/baggy", 5 | "homepage": "https://github.com/Tanuel/baggy", 6 | "license": "MIT", 7 | "private": true, 8 | "scripts": { 9 | "build": "tsc", 10 | "watch": "tsc --watch", 11 | "lint": "eslint . --ext .ts", 12 | "serve": "nodemon --exec 'ts-node' examples/express-fileserver", 13 | "serve-sqlite": "nodemon --exec 'ts-node' examples/express-sqlite", 14 | "serve-s3": "nodemon --exec 'ts-node' examples/express-s3" 15 | }, 16 | "devDependencies": { 17 | "@types/node": "^14.0.1", 18 | "@typescript-eslint/eslint-plugin": "^2.33.0", 19 | "@typescript-eslint/parser": "^2.33.0", 20 | "eslint": "^7.0.0", 21 | "eslint-config-prettier": "^6.11.0", 22 | "husky": "^4.2.5", 23 | "nodemon": "^2.0.4", 24 | "prettier": "^2.0.5", 25 | "pretty-quick": "^2.0.1", 26 | "ts-node": "^8.10.1", 27 | "typescript": "^3.9.2" 28 | }, 29 | "workspaces": [ 30 | "packages/*", 31 | "examples/*" 32 | ], 33 | "husky": { 34 | "hooks": { 35 | "pre-commit": "pretty-quick --staged" 36 | } 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /test/publish/Readme.md: -------------------------------------------------------------------------------- 1 | # Lorem Ipsum 2 | 3 | Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor 4 | invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et 5 | accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata 6 | sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet, consetetur 7 | sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna 8 | aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea 9 | rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit 10 | amet. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy 11 | eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. 12 | At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd 13 | gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. 14 | 15 | Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, 16 | vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio 17 | dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait 18 | nulla facilisi 19 | -------------------------------------------------------------------------------- /test/publish-scoped/Readme.md: -------------------------------------------------------------------------------- 1 | # Lorem Ipsum 2 | 3 | Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor 4 | invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et 5 | accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata 6 | sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet, consetetur 7 | sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna 8 | aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea 9 | rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit 10 | amet. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy 11 | eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. 12 | At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd 13 | gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. 14 | 15 | Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, 16 | vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio 17 | dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait 18 | nulla facilisi 19 | -------------------------------------------------------------------------------- /examples/express-fileserver/express-fileserver.ts: -------------------------------------------------------------------------------- 1 | import baggyRouter from "@baggy/express-router"; 2 | import express from "express"; 3 | import Fileserver from "@baggy/provider-fileserver"; 4 | import { Registry } from "@baggy/registry"; 5 | import { errorHandler, requestLogger } from "../util/logger"; 6 | import chalk from "chalk"; 7 | import { responseDecorator } from "../util/response-decorator"; 8 | 9 | const app = express(); 10 | const basePath = ".local"; 11 | const requestLogs = basePath + "/logs"; 12 | const errorLog = basePath + "/error.log"; 13 | const artifacts = basePath + "/artifacts"; 14 | const storage = new Fileserver(artifacts); 15 | 16 | const registry = new Registry({ 17 | artifactsUrl: "http://localhost:3000", 18 | storage, 19 | proxy: true, 20 | proxyCache: true, 21 | }); 22 | 23 | function info(...str: string[]): void { 24 | console.log(chalk.green.bold("Baggy Fileserver"), chalk.cyan(...str)); 25 | } 26 | 27 | app.use(requestLogger(requestLogs)); 28 | app.use(baggyRouter(registry, responseDecorator)); 29 | app.use(errorHandler(errorLog)); 30 | app.listen(3000, () => { 31 | info("Starting server on http://localhost:3000"); 32 | info("Access Logs =>", requestLogs); 33 | info("Error Logs =>", errorLog); 34 | info("Artifacts =>", artifacts); 35 | }); 36 | -------------------------------------------------------------------------------- /test.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | set -e 3 | 4 | TESTDIR=`realpath $(dirname $0)` 5 | export NPM_CONFIG_CACHE=$(pwd)/.local/.npm 6 | export YARN_CACHE_FOLDER=$(pwd)/.local/.yarn 7 | function switch { 8 | echo switching to $TESTDIR/$1 9 | cd $TESTDIR/$1 10 | echo now running in $PWD 11 | } 12 | 13 | rm -rf .local/.yarn 14 | rm -rf .local/.npm 15 | rm -rf .local/artifacts 16 | 17 | switch test/publish 18 | cp package.minimal.json package.json 19 | 20 | npm version --no-git-tag-version prerelease 21 | npm publish --tag prerelease 22 | 23 | npm version --no-git-tag-version prerelease --preid=whatever 24 | npm publish --tag whatever 25 | 26 | npm version --no-git-tag-version patch 27 | npm publish --tag latest 28 | 29 | switch test/publish-scoped 30 | cp package.minimal.json package.json 31 | 32 | npm version --no-git-tag-version minor 33 | npm publish --tag barry-allen 34 | 35 | npm version --no-git-tag-version patch 36 | npm publish 37 | 38 | npm version --no-git-tag-version major 39 | npm publish --tag latest 40 | 41 | echo TAGS 42 | npm dist-tag add no-scope@1.1.1 360-no-scope 43 | npm dist-tag add @local/publish-test@1.1.1 ehwat 44 | 45 | switch test/install 46 | echo NPM Install 47 | rm -rf node_modules package-lock.json 48 | npm install --ignore-scripts --force 49 | 50 | echo YARN INSTALL 51 | rm -rf node_modules yarn.lock package-lock.json 52 | yarn install --ignore-scripts --force -A 53 | rm -rf ${YARN_CACHE_FOLDER} 54 | rm -rf node_modules yarn.lock package-lock.json 55 | yarn install --ignore-scripts --force --no-cache -A 56 | -------------------------------------------------------------------------------- /packages/provider-s3/Readme.md: -------------------------------------------------------------------------------- 1 | # @baggy/provider-s3 2 | 3 | An AWS S3 Bucket storage provider for @baggy/registry. 4 | 5 | Saves everything on the specified path in a s3 bucket. 6 | 7 | ## Example 8 | 9 | Refer to the [example implementation](https://github.com/Tanuel/baggy/tree/master/examples/express-s3) 10 | 11 | ## Setup 12 | 13 | `yarn add sqlite3 @baggy/provider-s3 @baggy/registry aws-sdk` 14 | 15 | ```typescript 16 | import ProviderS3 from "@baggy/provider-s3"; 17 | import { Registry } from "@baggy/registry"; 18 | import S3 from "aws-sdk/clients/s3"; 19 | 20 | // somehow provide AWS credentials via env or AWS.config 21 | process.env.AWS_ACCESS_KEY_ID = "baggy-mock-key"; 22 | process.env.AWS_SECRET_ACCESS_KEY = "baggy-mock-key"; 23 | 24 | const s3 = new S3({ 25 | // pre-configure your S3 26 | s3ForcePathStyle: true, // this line is required. setting this later in the s3-provider does not work for some reason 27 | }); 28 | const providerConfig = { bucket: "baggy-registry-mock", s3: s3, prefix: "registry-prefix" }; 29 | 30 | const storage = new ProviderS3(providerConfig); 31 | 32 | const registry = new Registry({ 33 | artifactsUrl: "http://localhost:3000", 34 | storage, 35 | }); 36 | 37 | // Do something with the registry 38 | ``` 39 | 40 | ## Caveats 41 | 42 | Currently it is not easily possible to directly access the s3 bucket 43 | for file downloads when proxying is enabled, since there is no built-in 44 | fallback mechanism if an artifact is missing. This could maybe be solved with 45 | a redirect to the server on missing artifacts. 46 | -------------------------------------------------------------------------------- /examples/express-s3/express-s3.ts: -------------------------------------------------------------------------------- 1 | import baggyRouter from "@baggy/express-router"; 2 | import express from "express"; 3 | import ProviderS3 from "@baggy/provider-s3"; 4 | import { Registry } from "@baggy/registry"; 5 | import { errorHandler, requestLogger } from "../util/logger"; 6 | import chalk from "chalk"; 7 | import S3 from "aws-sdk/clients/s3"; 8 | import { responseDecorator } from "../util/response-decorator"; 9 | 10 | const app = express(); 11 | const basePath = ".local"; 12 | const requestLogs = basePath + "/logs"; 13 | const errorLog = basePath + "/error.log"; 14 | const artifacts = basePath + "/artifacts"; 15 | 16 | process.env.AWS_ACCESS_KEY_ID = "baggy-mock-key"; 17 | process.env.AWS_SECRET_ACCESS_KEY = "baggy-mock-key"; 18 | 19 | const s3 = new S3({ 20 | endpoint: "http://localhost:4572", 21 | s3ForcePathStyle: true, 22 | }); 23 | const providerConfig = { bucket: "baggy-registry-mock", s3 }; 24 | const storage = new ProviderS3(providerConfig); 25 | 26 | const registry = new Registry({ 27 | // TODO: fetch artifacts from bucket directly and use server as fallback 28 | // artifactsUrl: "http://localhost:4572/baggy-registry-mock", 29 | artifactsUrl: "http://localhost:3000", 30 | storage, 31 | proxy: true, 32 | proxyCache: true, 33 | }); 34 | 35 | function info(...str: string[]): void { 36 | console.log(chalk.green.bold("Baggy Express-S3"), chalk.cyan(...str)); 37 | } 38 | 39 | app.use(requestLogger(requestLogs)); 40 | app.use(baggyRouter(registry, responseDecorator)); 41 | app.use(errorHandler(errorLog)); 42 | app.listen(3000, () => { 43 | info("Starting server on http://localhost:3000"); 44 | info("Access Logs =>", requestLogs); 45 | info("Error Logs =>", errorLog); 46 | info("Artifacts =>", artifacts); 47 | }); 48 | -------------------------------------------------------------------------------- /examples/express-sqlite/express-sqlite.ts: -------------------------------------------------------------------------------- 1 | import router from "@baggy/express-router"; 2 | import express from "express"; 3 | import sqlite3 from "sqlite3"; 4 | import Database from "@baggy/provider-sqlite"; 5 | import fs from "fs"; 6 | import { Registry } from "@baggy/registry"; 7 | import { errorHandler, requestLogger } from "../util/logger"; 8 | import chalk from "chalk"; 9 | import { responseDecorator } from "../util/response-decorator"; 10 | 11 | const app = express(); 12 | const basePath = ".local"; 13 | const requestLogs = basePath + "/baggy-sqlite-logs"; 14 | const errorLog = basePath + "/baggy-sqlite-error.log"; 15 | const dbfile = basePath + "/baggy.sqlite"; 16 | sqlite3.verbose(); 17 | 18 | function info(...str: string[]): void { 19 | console.log(chalk.green.bold("Baggy SQLite"), chalk.cyan(...str)); 20 | } 21 | 22 | try { 23 | const stat = fs.statSync(".local"); 24 | if (!stat.isDirectory()) { 25 | info("Creating basepath @ ", basePath); 26 | fs.mkdirSync(basePath, { recursive: true }); 27 | } 28 | } catch (e) { 29 | if (e.code === "ENOENT") { 30 | info("Creating basepath @ ", basePath); 31 | fs.mkdirSync(basePath, { recursive: true }); 32 | } else { 33 | throw e; 34 | } 35 | } 36 | 37 | if (fs.existsSync(dbfile)) { 38 | info("remove previous database"); 39 | fs.unlinkSync(dbfile); 40 | } 41 | 42 | info("create database"); 43 | const db = new sqlite3.Database(dbfile, sqlite3.OPEN_READWRITE | sqlite3.OPEN_CREATE); 44 | 45 | const storage = new Database(db); 46 | 47 | info("create registry"); 48 | const registry = new Registry({ 49 | artifactsUrl: "http://localhost:3000", 50 | storage, 51 | proxy: true, 52 | proxyCache: true, 53 | }); 54 | 55 | app.use(requestLogger(requestLogs)); 56 | app.use(router(registry, responseDecorator)); 57 | app.use(errorHandler(errorLog)); 58 | app.listen(3000, () => { 59 | info("Starting server on http://localhost:3000"); 60 | info("Access Logs =>", requestLogs); 61 | info("Error Logs =>", errorLog); 62 | info("Database File =>", dbfile); 63 | }); 64 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Baggy NPM Registry 2 | 3 | Baggy is a reverse engineered NPM registry with a modular structure. 4 | 5 | You can provide your own functionality for storing artifacts and metadata. 6 | 7 | ## Disclaimer 8 | 9 | Baggy is not a production-ready registry. I have started this project for learning purposes 10 | and maybe at some point it can be used for specific setups. 11 | For now unit tests are missing as well as support for a few npm commands. 12 | 13 | This Project is als not published on NPM yet. 14 | 15 | ## Supported npm commands 16 | 17 | - [x] install/update/view 18 | - [x] publish 19 | - [x] unpublish 20 | - [x] audit (will proxy to the npm registry) 21 | - [x] ping 22 | - [x] dist-tag 23 | - [x] deprecate 24 | - [ ] login 25 | - [ ] whoami 26 | - [ ] team 27 | - [ ] token 28 | - [ ] search 29 | - [ ] stars 30 | - [ ] star 31 | - [ ] unstar 32 | 33 | ## Requirements 34 | 35 | - [yarn 1.x](https://yarnpkg.com/) 36 | - [node 12.x](https://nodejs.org/en/) (newer versions might work, but are not tested) 37 | 38 | ## Setup 39 | 40 | Clone the registry, then run one of those commands 41 | 42 | - `yarn install` 43 | - `yarn serve` to start the express server with filestorage 44 | - `yarn serve-sqlite` to start the express server with sqlite storage 45 | 46 | you can now run npm/yarn commands against `http://localhost:3000` by setting the "registry" option 47 | 48 | ## Development 49 | 50 | ### Quickstart 51 | 52 | 1. Run `yarn install` to install dependencies 53 | 2. Run `yarn serve` to start express server 54 | 3. Open a separate Terminal 55 | 4. Run `make test` to execute the test script which will execute a few commands like publish and install 56 | 57 | Using `ts-node` and [nodemon](https://www.npmjs.com/package/nodemon) 58 | we can restart the server on any file changes that affect the server. 59 | 60 | Files will be to the project root in `.local`. If the directory does not exist, it will be created. 61 | 62 | ### Formatting 63 | 64 | Code will be formatted on commit with `pretty-quick`. Also there is `yarn lint` 65 | 66 | ## Future Plans 67 | 68 | ### More providers 69 | 70 | Future Providers could be something like these: 71 | 72 | - AWS DynamoDB for Metadata 73 | - Other cloud providers 74 | 75 | ### Authentication 76 | 77 | Login should probably not be implemented in the core project (@baggy/registry), 78 | but rather as a kind of middleware for express and other implementations 79 | -------------------------------------------------------------------------------- /packages/provider-fileserver/provider-fileserver.ts: -------------------------------------------------------------------------------- 1 | import { promises as fs } from "fs"; 2 | import { dirname } from "path"; 3 | import { Provider, Meta } from "@baggy/registry"; 4 | 5 | class Fileserver implements Provider { 6 | constructor(private config: Config | string) {} 7 | 8 | private get path(): string { 9 | return typeof this.config === "string" ? this.config : this.config.base; 10 | } 11 | 12 | private getManifestPath(packageName: string): string { 13 | return packageName + "/manifest.json"; 14 | } 15 | 16 | public async deleteFile(path: string): Promise { 17 | path = this.path + "/" + path; 18 | await fs.unlink(path); 19 | return true; 20 | } 21 | 22 | public async deleteDir(path: string): Promise { 23 | path = this.path + "/" + path; 24 | await fs.rmdir(path, { recursive: true }); 25 | return true; 26 | } 27 | 28 | async getFile(path: string): Promise { 29 | return this.getArtifact(path); 30 | } 31 | 32 | async getMeta(packageName: string): Promise { 33 | const manifest = this.getManifestPath(packageName); 34 | const metaRaw = await this.getArtifact(manifest); 35 | return metaRaw ? JSON.parse(metaRaw.toString()) : null; 36 | } 37 | 38 | async writeMeta(packageName: string, meta: Meta, rev?: string): Promise { 39 | const name = rev ? "rev/" + rev + ".json" : "manifest.json"; 40 | const manifest = packageName + `/${name}`; 41 | await this.writeFile(manifest, JSON.stringify(meta, null, 2)); 42 | return true; 43 | } 44 | 45 | public async deleteMeta(packageName: string): Promise { 46 | const manifest = packageName + `/manifest.json`; 47 | return await this.deleteFile(manifest); 48 | } 49 | 50 | public async getArtifact(path: string): Promise { 51 | try { 52 | return await fs.readFile(this.path + "/" + path); 53 | } catch (e) { 54 | if (e.code === "ENOENT") { 55 | return null; 56 | } 57 | throw e; 58 | } 59 | } 60 | 61 | public async writeFile(path: string, content: any): Promise { 62 | path = this.path + "/" + path; 63 | await Fileserver.mkdir(dirname(path)); 64 | return await fs.writeFile(path, content); 65 | } 66 | 67 | private static async mkdir(path: string): Promise { 68 | try { 69 | const stat = await fs.stat(path); 70 | if (!stat.isDirectory()) { 71 | await fs.mkdir(path, { recursive: true }); 72 | } 73 | } catch (e) { 74 | if (e.code === "ENOENT") { 75 | await fs.mkdir(path, { recursive: true }); 76 | } else { 77 | throw e; 78 | } 79 | } 80 | } 81 | } 82 | 83 | export interface Config { 84 | /** 85 | * The base path where to put files 86 | */ 87 | base: string; 88 | } 89 | 90 | export default Fileserver; 91 | -------------------------------------------------------------------------------- /examples/util/logger.ts: -------------------------------------------------------------------------------- 1 | import { ErrorRequestHandler, NextFunction, Request, RequestHandler, Response } from "express"; 2 | import fs from "fs"; 3 | import path from "path"; 4 | import chalk from "chalk"; 5 | 6 | const logDir = ".local/debug-express-logs"; 7 | export function writeLog(filename: string, content: any, overwrite: boolean = false): void { 8 | if (filename) { 9 | if (!fs.existsSync(path.dirname(filename))) { 10 | fs.mkdirSync(path.dirname(filename), { recursive: true }); 11 | } 12 | if (overwrite && fs.existsSync(filename)) { 13 | fs.unlink(filename, (error) => { 14 | if (error !== null) { 15 | console.error(chalk.red("Unlink Error"), error); 16 | } 17 | }); 18 | } 19 | fs.appendFile(filename, content, (error) => { 20 | if (error !== null) { 21 | console.error(chalk.red("Cannot write error log"), error); 22 | } 23 | }); 24 | } else { 25 | console.warn(chalk.yellow("No Logfilename given")); 26 | } 27 | } 28 | 29 | export function debug(filename: string, content: any, overwrite: boolean = false): void { 30 | writeLog(path.resolve(logDir, filename), content, overwrite); 31 | } 32 | 33 | // export function errorHandler(filename?: string): (err: any, req: Request, res: Response, next: NextFunction) => Promise { 34 | export function errorHandler(filename?: string): ErrorRequestHandler { 35 | // Express requires a function to have 4 params to use it as an error handler 36 | // eslint-disable-next-line @typescript-eslint/no-unused-vars 37 | return async function (err: any, req: Request, res: Response, next: NextFunction): Promise { 38 | console.log(chalk.bgRed.bold("Error"), chalk.red(err.message)); 39 | if (filename) { 40 | const log = ` 41 | Path: ${req.path} 42 | Method: ${req.method} 43 | Body: ${err.body} 44 | Stack: ${err.stack} 45 | `; 46 | writeLog(filename, log); 47 | } else { 48 | console.warn(chalk.yellow("No Logfilename given")); 49 | } 50 | res.status(400); 51 | res.json({ error: "Invalid Request" }); 52 | res.end(); 53 | }; 54 | } 55 | 56 | export function requestLogger(logPath: string): RequestHandler { 57 | return function (req: Request, res: Response, next: NextFunction): void { 58 | try { 59 | const logDate = Date.now().toString().substr(4); 60 | const logReq = req.originalUrl.replace(/\//g, "|"); 61 | const logfile = `${logPath}/${logDate}-${req.method}-${logReq}.json`; 62 | console.log(chalk.bold(chalk.red(req.method)), chalk.yellow(req.originalUrl)); 63 | 64 | if (!fs.existsSync(logPath)) { 65 | fs.mkdirSync(logPath, { recursive: true }); 66 | } 67 | fs.writeFileSync( 68 | logfile, 69 | JSON.stringify( 70 | { 71 | path: req.path, 72 | query: req.query, 73 | originalUrl: req.originalUrl, 74 | method: req.method, 75 | headers: req.headers, 76 | body: req.body || "", 77 | }, 78 | null, 79 | 2 80 | ) 81 | ); 82 | } catch (e) { 83 | res.sendStatus(500); 84 | } 85 | next(); 86 | }; 87 | } 88 | -------------------------------------------------------------------------------- /packages/provider-s3/provider-s3.ts: -------------------------------------------------------------------------------- 1 | import { Provider, Meta } from "@baggy/registry"; 2 | import S3 from "aws-sdk/clients/s3"; 3 | 4 | const trimRegex = /^\/*/; 5 | function trimSlash(str: string): string { 6 | return str.replace(trimRegex, ""); 7 | } 8 | function resolve(...str: string[]) { 9 | return str.join("/"); 10 | } 11 | class ProviderS3 implements Provider { 12 | constructor(private config: Config) { 13 | // For some reason this won't work and has to be provided when 14 | // creating the AWS.S3 instance ... 15 | config.s3.config.update({ 16 | s3ForcePathStyle: true, 17 | }); 18 | } 19 | 20 | private get s3(): S3 { 21 | return this.config.s3; 22 | } 23 | private get bucket(): string { 24 | return this.config.bucket; 25 | } 26 | private get prefix(): string { 27 | return this.config.prefix ?? ""; 28 | } 29 | 30 | public async deleteFile(path: string): Promise { 31 | const params: S3.DeleteObjectRequest = { 32 | Bucket: this.bucket, 33 | Key: resolve(this.prefix, path), 34 | }; 35 | await this.s3.deleteObject(params).promise(); 36 | return true; 37 | } 38 | 39 | public async deleteDir(path: string): Promise { 40 | const params: S3.DeleteObjectRequest = { 41 | Bucket: this.bucket, 42 | Key: resolve(this.prefix, path), 43 | }; 44 | await this.s3.deleteObject(params).promise(); 45 | return true; 46 | } 47 | 48 | async getFile(path: string): Promise { 49 | return this.getArtifact(path); 50 | } 51 | 52 | async getMeta(packageName: string): Promise { 53 | const manifest = this.getManifestPath(packageName); 54 | const metaRaw = await this.getArtifact(manifest); 55 | return metaRaw ? JSON.parse(metaRaw.toString()) : null; 56 | } 57 | 58 | async writeMeta(packageName: string, meta: Meta, rev?: string): Promise { 59 | const name = rev ? "rev/" + rev + ".json" : "manifest.json"; 60 | const manifest = packageName + `/${name}`; 61 | await this.writeFile(manifest, JSON.stringify(meta, null, 2)); 62 | return true; 63 | } 64 | 65 | public async deleteMeta(packageName: string): Promise { 66 | const manifest = packageName + `/manifest.json`; 67 | return await this.deleteFile(manifest); 68 | } 69 | 70 | public async getArtifact(path: string): Promise { 71 | const params: S3.GetObjectRequest = { 72 | Bucket: this.bucket, 73 | Key: resolve(this.prefix, path), 74 | }; 75 | try { 76 | const result = await this.s3.getObject(params).promise(); 77 | return result.Body ? Buffer.from(result.Body) : null; 78 | } catch (e) { 79 | if (e.code === "NoSuchKey") { 80 | return null; 81 | } 82 | throw e; 83 | } 84 | } 85 | 86 | public async writeFile(path: string, content: any): Promise { 87 | const params: S3.PutObjectRequest = { 88 | Bucket: this.bucket, 89 | Key: resolve(this.prefix, path), 90 | Body: content, 91 | }; 92 | await this.s3.upload(params).promise(); 93 | } 94 | 95 | private getManifestPath(packageName: string): string { 96 | return packageName + "/manifest.json"; 97 | } 98 | } 99 | 100 | export interface Config { 101 | /** 102 | * Name of the bucket 103 | */ 104 | bucket: string; 105 | /** 106 | * An AWS S3 instance from the aws-sdk with required 107 | * configuration like credentials 108 | * or default params 109 | * see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#constructor-property 110 | */ 111 | s3: S3; 112 | /** 113 | * S3 path prefix 114 | */ 115 | prefix?: string; 116 | } 117 | 118 | export default ProviderS3; 119 | -------------------------------------------------------------------------------- /packages/registry/models.ts: -------------------------------------------------------------------------------- 1 | export interface Meta { 2 | //Required Tags 3 | _id: string; 4 | _rev: string; 5 | name: string; 6 | "dist-tags": { 7 | [key: string]: string; 8 | }; 9 | time: { 10 | created: string; 11 | modified: string; 12 | [key: string]: string; 13 | }; 14 | users?: Human[]; 15 | versions: { 16 | [key: string]: MetaVersion; 17 | }; 18 | _attachments?: { 19 | [key: string]: MetaAttachment; 20 | }; 21 | //Hoisted from package.json 22 | author?: Human; 23 | bugs?: string; 24 | contributors?: Human[]; 25 | description?: string; 26 | homepage?: string; 27 | keywords?: string[]; 28 | license?: string; 29 | maintainers?: Human[]; 30 | readme?: string; 31 | readmeFilename?: string; 32 | repository?: string | Repository; 33 | } 34 | 35 | export interface Repository { 36 | type: string; 37 | url: string; 38 | } 39 | 40 | export interface Human { 41 | name?: string; 42 | email?: string; 43 | url?: string; 44 | } 45 | 46 | export interface MetaAttachment { 47 | content_type: string; 48 | data: string; 49 | length: number; 50 | } 51 | 52 | export interface MetaVersion { 53 | // Required values 54 | _id: string; 55 | _nodeVersion: string; 56 | _npmVersion: string; 57 | name: string; 58 | version: string; 59 | dist: MetaDist; 60 | 61 | // Optional 62 | _hasShrinkwrap?: boolean; 63 | _npmUser?: Human; 64 | author?: Human; 65 | bin?: KeyValueMap; 66 | bugs?: string; 67 | bundleDependencies?: KeyValueMap; 68 | contributors?: Human[]; 69 | dependencies?: KeyValueMap; 70 | deprecated?: string; 71 | description?: string; 72 | devDependencies?: KeyValueMap; 73 | directories?: KeyValueMap; 74 | engines?: KeyValueMap; 75 | homepage?: string; 76 | keywords?: string[]; 77 | license?: string; 78 | maintainers?: Human[]; 79 | optionalDependencies?: KeyValueMap; 80 | peerDependencies?: KeyValueMap; 81 | readme?: string; 82 | readmeFilename?: string; 83 | repository?: string | Repository; 84 | scripts?: KeyValueMap; 85 | [key: string]: any; 86 | } 87 | 88 | export interface MetaDist extends StringMap { 89 | integrity?: string; 90 | shasum: string; 91 | tarball: string; 92 | } 93 | 94 | interface StringMap { 95 | [key: string]: T; 96 | } 97 | 98 | interface KeyValueMap { 99 | [key: string]: string; 100 | } 101 | 102 | /** 103 | * Interface to store Metadata for Packages 104 | */ 105 | export interface MetaProvider { 106 | getMeta(packageName: string): Promise | never; 107 | 108 | writeMeta(packageName: string, data: Meta, rev?: string): Promise; 109 | 110 | deleteMeta(packageName: string): Promise; 111 | } 112 | 113 | export function isMetaProvider(storage: any): storage is MetaProvider { 114 | return "getMeta" in storage && "writeMeta" in storage && "deleteMeta" in storage; 115 | } 116 | 117 | export interface FileProvider { 118 | getFile(path: string): Promise | never; 119 | 120 | writeFile(path: string, content: Buffer): Promise; 121 | 122 | deleteFile(path: string): Promise; 123 | 124 | deleteDir(path: string): Promise; 125 | } 126 | 127 | export function isFileProvider(storage: any): storage is FileProvider { 128 | return "getFile" in storage && "writeFile" in storage && "deleteFile" in storage && "deleteDir" in storage; 129 | } 130 | 131 | export type Provider = FileProvider & MetaProvider; 132 | 133 | export function createMeta(meta: Meta): Meta { 134 | return { 135 | _id: meta._id, 136 | "dist-tags": meta["dist-tags"], 137 | _rev: "rev-" + Date.now(), 138 | name: meta.name, 139 | time: { created: new Date().toISOString(), modified: new Date().toISOString() }, 140 | versions: meta.versions, 141 | }; 142 | } 143 | -------------------------------------------------------------------------------- /packages/provider-sqlite/provider-sqlite.ts: -------------------------------------------------------------------------------- 1 | import { Meta, Provider } from "@baggy/registry"; 2 | import sqlite3 from "sqlite3"; 3 | 4 | const Model = { 5 | metadata: "metadata", 6 | artifacts: "artifacts", 7 | }; 8 | 9 | function bootstrap(db: sqlite3.Database): void { 10 | const queries = [ 11 | `CREATE TABLE IF NOT EXISTS "${Model.metadata}" ( 12 | "key" TEXT NOT NULL UNIQUE, 13 | "value" TEXT, 14 | PRIMARY KEY("key") 15 | );`, 16 | `CREATE TABLE IF NOT EXISTS "${Model.artifacts}" ( 17 | "key" TEXT NOT NULL UNIQUE, 18 | "value" BLOB, 19 | PRIMARY KEY("key") 20 | );`, 21 | ]; 22 | 23 | db.serialize(() => { 24 | queries.forEach((query) => { 25 | db.run(query); 26 | }); 27 | }); 28 | } 29 | 30 | export default class Database implements Provider { 31 | constructor(private db: sqlite3.Database) { 32 | bootstrap(db); 33 | } 34 | 35 | async deleteDir(path: string): Promise { 36 | return new Promise((resolve, reject) => { 37 | const stmt = this.db.prepare(`DELETE FROM ${Model.artifacts} WHERE key LIKE ?`); 38 | stmt 39 | .run(path + "%", (err) => { 40 | if (err === null) resolve(true); 41 | else reject(err); 42 | }) 43 | .finalize(); 44 | }); 45 | } 46 | 47 | async deleteFile(path: string): Promise { 48 | return new Promise((resolve, reject) => { 49 | const stmt = this.db.prepare(`DELETE FROM ${Model.artifacts} WHERE key = ?`); 50 | stmt 51 | .run(path, (err) => { 52 | if (err === null) resolve(true); 53 | else reject(err); 54 | }) 55 | .finalize(); 56 | }); 57 | } 58 | 59 | async deleteMeta(packageName: string): Promise { 60 | return new Promise((resolve, reject) => { 61 | const stmt = this.db.prepare(`DELETE FROM ${Model.metadata} WHERE key = ?`); 62 | stmt 63 | .run(packageName, (err) => { 64 | if (err === null) resolve(true); 65 | else reject(err); 66 | }) 67 | .finalize(); 68 | }); 69 | } 70 | 71 | async getFile(path: string): Promise { 72 | return new Promise((resolve, reject) => { 73 | const stmt = this.db.prepare(`SELECT value FROM ${Model.artifacts} WHERE key = ?`); 74 | stmt 75 | .get(path, (err, row) => { 76 | if (err === null) { 77 | resolve(row && row.value ? row.value : null); 78 | } else { 79 | reject(err); 80 | } 81 | }) 82 | .finalize(); 83 | }); 84 | } 85 | 86 | async getMeta(packageName: string): Promise { 87 | return new Promise((resolve, reject) => { 88 | const stmt = this.db.prepare(`SELECT value FROM ${Model.metadata} WHERE key = ?`); 89 | stmt 90 | .get(packageName, (err, row) => { 91 | if (err === null) { 92 | resolve(row && row.value ? JSON.parse(row.value) : null); 93 | } else { 94 | reject(err); 95 | } 96 | }) 97 | .finalize(); 98 | }); 99 | } 100 | 101 | async writeFile(path: string, content: Buffer): Promise { 102 | return new Promise((resolve, reject) => { 103 | const stmt = this.db.prepare(`REPLACE INTO ${Model.artifacts} (key, value) VALUES(?, ?)`); 104 | stmt 105 | .run([path, content], (err: Error | null) => { 106 | if (err === null) { 107 | resolve(true); 108 | } else { 109 | reject(err); 110 | } 111 | }) 112 | .finalize(); 113 | }); 114 | } 115 | 116 | // eslint-disable-next-line @typescript-eslint/no-unused-vars 117 | async writeMeta(packageName: string, data: Meta, rev?: string): Promise { 118 | return new Promise((resolve, reject) => { 119 | const stmt = this.db.prepare(`REPLACE INTO ${Model.metadata} (key, value) VALUES(?, ?)`); 120 | stmt 121 | .run([packageName, JSON.stringify(data)], (err: Error | null) => { 122 | if (err === null) { 123 | resolve(true); 124 | } else { 125 | reject(err); 126 | } 127 | }) 128 | .finalize(); 129 | }); 130 | } 131 | } 132 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Basic Options */ 4 | "target": "ES2019" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'. */, 5 | "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */, 6 | "lib": ["es2019", "dom"] /* Specify library files to be included in the compilation. */, 7 | "declaration": true /* Generates corresponding '.d.ts' file. */, 8 | // "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */ 9 | // "sourceMap": true, /* Generates corresponding '.map' file. */ 10 | // "outFile": "./", /* Concatenate and emit output to single file. */ 11 | // "outDir": "./", /* Redirect output structure to the directory. */ 12 | // "rootDir": "./", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */ 13 | // "composite": true, /* Enable project compilation */ 14 | // "incremental": true, /* Enable incremental compilation */ 15 | // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ 16 | // "removeComments": true, /* Do not emit comments to output. */ 17 | // "noEmit": true, /* Do not emit outputs. */ 18 | // "importHelpers": true, /* Import emit helpers from 'tslib'. */ 19 | // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ 20 | // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ 21 | 22 | /* Strict Type-Checking Options */ 23 | "strict": true /* Enable all strict type-checking options. */, 24 | "noImplicitAny": true /* Raise error on expressions and declarations with an implied 'any' type. */, 25 | // "strictNullChecks": true, /* Enable strict null checks. */ 26 | // "strictFunctionTypes": true, /* Enable strict checking of function types. */ 27 | // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ 28 | // "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */ 29 | // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ 30 | // "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */ 31 | 32 | /* Additional Checks */ 33 | // "noUnusedLocals": true, /* Report errors on unused locals. */ 34 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 35 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 36 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 37 | 38 | /* Module Resolution Options */ 39 | // "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ 40 | // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ 41 | // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ 42 | // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ 43 | // "typeRoots": [], /* List of folders to include type definitions from. */ 44 | // "types": [], /* Type declaration files to be included in compilation. */ 45 | // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ 46 | "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */ 47 | // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ 48 | 49 | /* Source Map Options */ 50 | // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ 51 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 52 | // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ 53 | // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ 54 | 55 | /* Experimental Options */ 56 | // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ 57 | // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ 58 | } 59 | } 60 | -------------------------------------------------------------------------------- /packages/registry/registry.ts: -------------------------------------------------------------------------------- 1 | import http from "http"; 2 | import https from "https"; 3 | import { Meta, Provider, createMeta, MetaProvider, FileProvider, isMetaProvider, isFileProvider } from "./models"; 4 | import { URL } from "url"; 5 | import zlib from "zlib"; 6 | 7 | const configDefault: Partial = { 8 | proxy: false, 9 | proxyUrl: "https://registry.npmjs.org/", 10 | proxyCache: true, 11 | }; 12 | 13 | type Res = Promise>; 14 | type ResFull = Promise>>; 15 | 16 | interface Route { 17 | pattern: RegExp | string; 18 | GET?: (request: Request, match: any) => Res | ResFull; 19 | PUT?: (request: Request, match: any) => Res | ResFull; 20 | POST?: (request: Request, match: any) => Res | ResFull; 21 | DELETE?: (request: Request, match: any) => Res | ResFull; 22 | } 23 | 24 | export class Registry { 25 | private readonly config: Config; 26 | private readonly metaStorage: MetaProvider; 27 | private readonly fileStorage: FileProvider; 28 | constructor(config: Config) { 29 | this.config = { ...configDefault, ...config }; 30 | this.metaStorage = isMetaProvider(this.config.storage) ? this.config.storage : this.config.storage.meta; 31 | this.fileStorage = isFileProvider(this.config.storage) ? this.config.storage : this.config.storage.files; 32 | } 33 | 34 | private readonly routes: Route[] = [ 35 | { 36 | pattern: /^\/(?[^/]+)$/, 37 | GET: this.getPackage, 38 | PUT: this.putPackage, 39 | }, 40 | { 41 | pattern: /^\/(?[^/]+)\/-rev\/(?.*)$/, 42 | PUT: this.putRevision, 43 | DELETE: this.deletePackage, 44 | }, 45 | { 46 | pattern: /^\/-\/package\/(?[^/]+)\/dist-tags$/, 47 | GET: this.getDistTags, 48 | PUT: this.putDistTag, 49 | }, 50 | { 51 | pattern: /^\/-\/package\/(?[^/]+)\/dist-tags\/(?[^/]+)$/, 52 | PUT: this.putDistTag, 53 | }, 54 | { 55 | pattern: /^\/-\/npm\/v1\/security\/audits(\/quick)?$/, 56 | POST: this.audit, 57 | }, 58 | { 59 | pattern: /^\/-\/ping$/, 60 | GET: async (): Promise<{ statusCode: number }> => ({ statusCode: 200 }), 61 | }, 62 | { 63 | pattern: /^\/-\/v1\/login$/, 64 | POST: this.login, 65 | }, 66 | { 67 | pattern: /^\/-\/user\/org\.couchdb\.user:(?[\w-*~]+)$/, 68 | PUT: this.proxy, 69 | }, 70 | { 71 | pattern: /^(?!\/-\/)\/(?.+?)(?:\/-rev\/(?.*))?$/, 72 | GET: this.getArtifact, 73 | DELETE: this.deleteArtifact, 74 | }, 75 | ]; 76 | 77 | public async handle(request: Request): Res { 78 | const { path, method } = request; 79 | for (const route of this.routes) { 80 | const match = path.match(route.pattern); 81 | if (match) { 82 | if (match.groups && match.groups.pkg) { 83 | match.groups.pkg = match.groups.pkg.replace("%2f", "/"); 84 | } 85 | if (method in route) { 86 | // eslint-disable-next-line 87 | // @ts-ignore 88 | return await route[method].call(this, request, match); 89 | } 90 | } 91 | } 92 | throw Error(`No Operation found for ${request.method} ${path}`); 93 | } 94 | 95 | public async audit(request: Request): Res { 96 | const res: Response = await this.proxy(request); 97 | if (res.body) { 98 | res.body = res.body.toString(); 99 | } 100 | return res; 101 | } 102 | 103 | public async putPackage(request: Request, match: any): Res { 104 | const meta = request.body as Meta; 105 | const { pkg } = match.groups; 106 | if (pkg !== meta.name) { 107 | throw Error(`Package names from URL (${pkg}) and body.name (${meta.name}) do not match`); 108 | } 109 | const getMeta = this.metaStorage.getMeta(meta.name); 110 | if (meta._attachments) { 111 | const entries = Object.entries(meta._attachments); 112 | await entries.reduce(async (promise, [key, value]) => { 113 | await promise; 114 | await this.fileStorage.writeFile(`/${meta.name}/-/${key}`, Buffer.from(value.data, "base64")); 115 | }, Promise.resolve()); 116 | } 117 | let currentMeta = await getMeta; 118 | if (currentMeta === null) { 119 | currentMeta = createMeta(meta); 120 | } else { 121 | // We do not need to wait for the meta to have been written, but some IDEs will throw a warning 122 | // noinspection ES6MissingAwait 123 | this.metaStorage.writeMeta(pkg, currentMeta, currentMeta._rev); 124 | currentMeta._rev = "rev-" + Date.now(); 125 | } 126 | Object.assign(currentMeta["dist-tags"], meta["dist-tags"]); 127 | // Rewrite url origins to how we want them to be. 128 | // This means we can store the artifacts in a different place than the metadata 129 | Object.entries(meta.versions).forEach(([, value]) => { 130 | const tb = new URL(value.dist.tarball); 131 | value.dist.tarball = tb.href.replace(tb.origin, this.config.artifactsUrl); 132 | }); 133 | Object.assign(currentMeta.versions, meta.versions); 134 | if ("latest" in meta["dist-tags"]) { 135 | currentMeta.readme = meta.readme; 136 | currentMeta.readmeFilename = meta.readmeFilename; 137 | currentMeta.author = meta.author; 138 | currentMeta.maintainers = meta.maintainers; 139 | currentMeta.description = meta.description; 140 | } 141 | await this.putPackageMeta(meta.name, currentMeta); 142 | return { statusCode: 200 }; 143 | } 144 | 145 | public async getPackage(request: Request, match: any): ResFull { 146 | const { pkg } = match.groups; 147 | const result = await this.metaStorage.getMeta(pkg); 148 | if (result === null && this.config.proxy) { 149 | const { statusCode, body } = await this.proxy(request); 150 | try { 151 | if (statusCode < 400 && body) { 152 | const j = JSON.parse(body.toString()); 153 | if (this.config.proxyCache) { 154 | Object.keys(j.versions as any).forEach((version) => { 155 | const tb = j.versions[version].dist.tarball; 156 | const u = new URL(tb); 157 | j.versions[version].dist.tarball = u.href.replace(u.origin, this.config.artifactsUrl || u.origin); 158 | }); 159 | } 160 | return { statusCode, body: j }; 161 | } 162 | return { statusCode, body: body instanceof Buffer ? JSON.parse(body.toString()) : null }; 163 | } catch (e) { 164 | console.error("Proxy Error", request.path, e.toString(), e.stack, body?.toString()); 165 | throw e; 166 | // return {statusCode: 500, body: null}; 167 | } 168 | } 169 | return { statusCode: 200, body: result }; 170 | } 171 | 172 | public async putPackageMeta(packageName: string, data: Meta): Res { 173 | await this.metaStorage.writeMeta(packageName, data); 174 | return { 175 | statusCode: 200, 176 | }; 177 | } 178 | 179 | /** 180 | * Send a proxy request to the npm registry and return the response as a buffer 181 | * @param proxyReq 182 | */ 183 | private async proxy(proxyReq: Request): Res { 184 | return new Promise((resolve, reject) => { 185 | // prepare options 186 | const options: https.RequestOptions = { 187 | host: "registry.npmjs.org", 188 | method: proxyReq.method, 189 | path: proxyReq.path, 190 | headers: { ...proxyReq.headers, host: "registry.npmjs.org" }, 191 | }; 192 | 193 | // init the request 194 | const req = https 195 | .request(options) 196 | .on("response", (res) => { 197 | // Container for returned chunks 198 | const chunks: Buffer[] = []; 199 | const { headers, statusCode } = res; 200 | // console.log("PROXY", proxyReq.path, res.statusCode); 201 | res.on("data", (chunk) => { 202 | chunks.push(chunk); 203 | }); 204 | res.on("end", () => { 205 | const r = { body: Buffer.concat(chunks), statusCode: statusCode || 200 }; 206 | // unzip the buffer if required 207 | if (headers["content-encoding"] === "gzip") { 208 | r.body = zlib.unzipSync(r.body); 209 | } 210 | resolve(r); 211 | }); 212 | }) 213 | .on("error", (e) => { 214 | reject(e); 215 | }); 216 | 217 | // Proxy body handling 218 | let body: string | Buffer = ""; 219 | // Check if body is an object 220 | if (typeof proxyReq.body === "object" && Object.entries(proxyReq.body).length > 0) { 221 | try { 222 | body = JSON.stringify(proxyReq.body); 223 | } catch (e) { 224 | reject(e); 225 | } 226 | // Check if body is a string 227 | } else if (typeof proxyReq.body === "string" && proxyReq.body.length > 0) { 228 | body = proxyReq.body; 229 | } 230 | // check if we need to zip the body 231 | if (body) { 232 | if (proxyReq.headers["content-encoding"] === "gzip") { 233 | body = zlib.gzipSync(body); 234 | } 235 | req.write(body); 236 | } 237 | req.end(); 238 | }); 239 | } 240 | 241 | public async getDistTags(request: Request, match: any): Res { 242 | const { statusCode, body } = await this.getPackage(request, match); 243 | return { statusCode, body: body ? body["dist-tags"] : {} }; 244 | } 245 | 246 | public async putDistTag(request: Request, match: any): Res { 247 | const { tag, pkg } = match.groups; 248 | const version: string = request.body as string; 249 | const { body } = await this.getPackage(request, match); 250 | if (body === null) { 251 | throw new Error("Not found"); 252 | } 253 | body["dist-tags"][tag] = version; 254 | await this.putPackageMeta(pkg, body); 255 | return { statusCode: 200 }; 256 | } 257 | 258 | public async getArtifact(request: Request): Res { 259 | const artifact = await this.fileStorage.getFile(request.path); 260 | if (!artifact) { 261 | const prox = await this.proxy(request); 262 | if (prox.statusCode < 400 && prox.body) { 263 | this.putArtifact(request.path, prox.body); 264 | } 265 | return prox; 266 | } 267 | return { statusCode: 200, body: artifact }; 268 | } 269 | 270 | public async putArtifact(path: string, buffer: Buffer): Promise { 271 | return await this.fileStorage.writeFile(path, buffer); 272 | } 273 | 274 | private async putRevision(request: Request, match: any): Res { 275 | const { pkg, rev } = match.groups; 276 | let status = 200; 277 | const current = await this.metaStorage.getMeta(pkg); 278 | if (current) { 279 | await this.metaStorage.writeMeta(pkg, current, rev); 280 | await this.metaStorage.writeMeta(pkg, request.body as Meta); 281 | } else { 282 | status = 404; 283 | } 284 | return { statusCode: status }; 285 | } 286 | 287 | private async deletePackage(request: Request, match: any): Res { 288 | const { pkg } = match.groups; 289 | let success = await this.metaStorage.deleteMeta(pkg); 290 | if (success) { 291 | success = await this.fileStorage.deleteDir(pkg); 292 | } 293 | return { statusCode: success ? 200 : 500 }; 294 | } 295 | 296 | private async deleteArtifact(request: Request, match: any): Res { 297 | const { path } = match.groups; 298 | const success = await this.fileStorage.deleteFile(path); 299 | console.log("DELETED", path); 300 | return { statusCode: success ? 200 : 500 }; 301 | } 302 | 303 | private async login(request: Request): Res { 304 | return await this.proxy(request); 305 | } 306 | } 307 | 308 | export interface Config { 309 | /** 310 | * The base url of artifacts 311 | * Will be used for dependency proxying 312 | */ 313 | artifactsUrl: string; 314 | /** 315 | * A Storage interface where we place the files 316 | */ 317 | storage: Provider | StorageConfig; 318 | /** 319 | * Enable dependency proxy 320 | * Lookup dependencies in a different registry 321 | */ 322 | proxy?: boolean; 323 | /** 324 | * Registry url for proxying 325 | * e.g. https://registry.npmjs.org/ 326 | */ 327 | proxyUrl?: string; 328 | /** 329 | * Enable proxy caching 330 | */ 331 | proxyCache?: boolean; 332 | } 333 | 334 | export interface StorageConfig { 335 | meta: MetaProvider; 336 | files: FileProvider; 337 | } 338 | 339 | export interface Request { 340 | body?: object | string; 341 | headers: http.IncomingHttpHeaders; 342 | method: string; 343 | path: string; 344 | query: any; 345 | } 346 | 347 | export interface Response { 348 | body?: T; 349 | statusCode: number; 350 | } 351 | -------------------------------------------------------------------------------- /yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | "@babel/code-frame@^7.0.0": 6 | version "7.8.3" 7 | resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.8.3.tgz#33e25903d7481181534e12ec0a25f16b6fcf419e" 8 | integrity sha512-a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g== 9 | dependencies: 10 | "@babel/highlight" "^7.8.3" 11 | 12 | "@babel/helper-validator-identifier@^7.9.0": 13 | version "7.9.5" 14 | resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz#90977a8e6fbf6b431a7dc31752eee233bf052d80" 15 | integrity sha512-/8arLKUFq882w4tWGj9JYzRpAlZgiWUJ+dtteNTDqrRBz9Iguck9Rn3ykuBDoUwh2TO4tSAJlrxDUOXWklJe4g== 16 | 17 | "@babel/highlight@^7.8.3": 18 | version "7.9.0" 19 | resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.9.0.tgz#4e9b45ccb82b79607271b2979ad82c7b68163079" 20 | integrity sha512-lJZPilxX7Op3Nv/2cvFdnlepPXDxi29wxteT57Q965oc5R9v86ztx0jfxVrTcBk8C2kcPkkDa2Z4T3ZsPPVWsQ== 21 | dependencies: 22 | "@babel/helper-validator-identifier" "^7.9.0" 23 | chalk "^2.0.0" 24 | js-tokens "^4.0.0" 25 | 26 | "@sindresorhus/is@^0.14.0": 27 | version "0.14.0" 28 | resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-0.14.0.tgz#9fb3a3cf3132328151f353de4632e01e52102bea" 29 | integrity sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ== 30 | 31 | "@szmarczak/http-timer@^1.1.2": 32 | version "1.1.2" 33 | resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-1.1.2.tgz#b1665e2c461a2cd92f4c1bbf50d5454de0d4b421" 34 | integrity sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA== 35 | dependencies: 36 | defer-to-connect "^1.0.1" 37 | 38 | "@types/body-parser@*": 39 | version "1.19.0" 40 | resolved "https://registry.yarnpkg.com/@types/body-parser/-/body-parser-1.19.0.tgz#0685b3c47eb3006ffed117cdd55164b61f80538f" 41 | integrity sha512-W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ== 42 | dependencies: 43 | "@types/connect" "*" 44 | "@types/node" "*" 45 | 46 | "@types/color-name@^1.1.1": 47 | version "1.1.1" 48 | resolved "https://registry.yarnpkg.com/@types/color-name/-/color-name-1.1.1.tgz#1c1261bbeaa10a8055bbc5d8ab84b7b2afc846a0" 49 | integrity sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ== 50 | 51 | "@types/connect@*": 52 | version "3.4.33" 53 | resolved "https://registry.yarnpkg.com/@types/connect/-/connect-3.4.33.tgz#31610c901eca573b8713c3330abc6e6b9f588546" 54 | integrity sha512-2+FrkXY4zllzTNfJth7jOqEHC+enpLeGslEhpnTAkg21GkRrWV4SsAtqchtT4YS9/nODBU2/ZfsBY2X4J/dX7A== 55 | dependencies: 56 | "@types/node" "*" 57 | 58 | "@types/eslint-visitor-keys@^1.0.0": 59 | version "1.0.0" 60 | resolved "https://registry.yarnpkg.com/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz#1ee30d79544ca84d68d4b3cdb0af4f205663dd2d" 61 | integrity sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag== 62 | 63 | "@types/express-serve-static-core@*": 64 | version "4.17.7" 65 | resolved "https://registry.yarnpkg.com/@types/express-serve-static-core/-/express-serve-static-core-4.17.7.tgz#dfe61f870eb549dc6d7e12050901847c7d7e915b" 66 | integrity sha512-EMgTj/DF9qpgLXyc+Btimg+XoH7A2liE8uKul8qSmMTHCeNYzydDKFdsJskDvw42UsesCnhO63dO0Grbj8J4Dw== 67 | dependencies: 68 | "@types/node" "*" 69 | "@types/qs" "*" 70 | "@types/range-parser" "*" 71 | 72 | "@types/express@^4.17.2": 73 | version "4.17.6" 74 | resolved "https://registry.yarnpkg.com/@types/express/-/express-4.17.6.tgz#6bce49e49570507b86ea1b07b806f04697fac45e" 75 | integrity sha512-n/mr9tZI83kd4azlPG5y997C/M4DNABK9yErhFM6hKdym4kkmd9j0vtsJyjFIwfRBxtrxZtAfGZCNRIBMFLK5w== 76 | dependencies: 77 | "@types/body-parser" "*" 78 | "@types/express-serve-static-core" "*" 79 | "@types/qs" "*" 80 | "@types/serve-static" "*" 81 | 82 | "@types/json-schema@^7.0.3": 83 | version "7.0.4" 84 | resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.4.tgz#38fd73ddfd9b55abb1e1b2ed578cb55bd7b7d339" 85 | integrity sha512-8+KAKzEvSUdeo+kmqnKrqgeE+LcA0tjYWFY7RPProVYwnqDjukzO+3b6dLD56rYX5TdWejnEOLJYOIeh4CXKuA== 86 | 87 | "@types/mime@*": 88 | version "2.0.2" 89 | resolved "https://registry.yarnpkg.com/@types/mime/-/mime-2.0.2.tgz#857a118d8634c84bba7ae14088e4508490cd5da5" 90 | integrity sha512-4kPlzbljFcsttWEq6aBW0OZe6BDajAmyvr2xknBG92tejQnvdGtT9+kXSZ580DqpxY9qG2xeQVF9Dq0ymUTo5Q== 91 | 92 | "@types/minimatch@^3.0.3": 93 | version "3.0.3" 94 | resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.3.tgz#3dca0e3f33b200fc7d1139c0cd96c1268cadfd9d" 95 | integrity sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA== 96 | 97 | "@types/node@*", "@types/node@^14.0.1": 98 | version "14.0.1" 99 | resolved "https://registry.yarnpkg.com/@types/node/-/node-14.0.1.tgz#5d93e0a099cd0acd5ef3d5bde3c086e1f49ff68c" 100 | integrity sha512-FAYBGwC+W6F9+huFIDtn43cpy7+SzG+atzRiTfdp3inUKL2hXnd4rG8hylJLIh4+hqrQy1P17kvJByE/z825hA== 101 | 102 | "@types/parse-json@^4.0.0": 103 | version "4.0.0" 104 | resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" 105 | integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== 106 | 107 | "@types/qs@*": 108 | version "6.9.2" 109 | resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.2.tgz#faab98ec4f96ee72c829b7ec0983af4f4d343113" 110 | integrity sha512-a9bDi4Z3zCZf4Lv1X/vwnvbbDYSNz59h3i3KdyuYYN+YrLjSeJD0dnphdULDfySvUv6Exy/O0K6wX/kQpnPQ+A== 111 | 112 | "@types/range-parser@*": 113 | version "1.2.3" 114 | resolved "https://registry.yarnpkg.com/@types/range-parser/-/range-parser-1.2.3.tgz#7ee330ba7caafb98090bece86a5ee44115904c2c" 115 | integrity sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA== 116 | 117 | "@types/serve-static@*": 118 | version "1.13.3" 119 | resolved "https://registry.yarnpkg.com/@types/serve-static/-/serve-static-1.13.3.tgz#eb7e1c41c4468272557e897e9171ded5e2ded9d1" 120 | integrity sha512-oprSwp094zOglVrXdlo/4bAHtKTAxX6VT8FOZlBKrmyLbNvE1zxZyJ6yikMVtHIvwP45+ZQGJn+FdXGKTozq0g== 121 | dependencies: 122 | "@types/express-serve-static-core" "*" 123 | "@types/mime" "*" 124 | 125 | "@types/sqlite3@^3.1.6": 126 | version "3.1.6" 127 | resolved "https://registry.yarnpkg.com/@types/sqlite3/-/sqlite3-3.1.6.tgz#554ce76f886eb187cfc86e2f0bb67cbac4f568ce" 128 | integrity sha512-OBsK0KIGUICExQ/ZvnPY4cKx5Kz4NcrVyGTIvOL5y4ajXu7r++RfBajfpGfGDmDVCKcoCDX1dO84/oeyeITnxA== 129 | dependencies: 130 | "@types/node" "*" 131 | 132 | "@typescript-eslint/eslint-plugin@^2.33.0": 133 | version "2.33.0" 134 | resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.33.0.tgz#d6c8319d5011b4783bb3d2dadf105d8bdd499bd5" 135 | integrity sha512-QV6P32Btu1sCI/kTqjTNI/8OpCYyvlGjW5vD8MpTIg+HGE5S88HtT1G+880M4bXlvXj/NjsJJG0aGcVh0DdbeQ== 136 | dependencies: 137 | "@typescript-eslint/experimental-utils" "2.33.0" 138 | functional-red-black-tree "^1.0.1" 139 | regexpp "^3.0.0" 140 | tsutils "^3.17.1" 141 | 142 | "@typescript-eslint/experimental-utils@2.33.0": 143 | version "2.33.0" 144 | resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-2.33.0.tgz#000f1e5f344fbea1323dc91cc174805d75f99a03" 145 | integrity sha512-qzPM2AuxtMrRq78LwyZa8Qn6gcY8obkIrBs1ehqmQADwkYzTE1Pb4y2W+U3rE/iFkSWcWHG2LS6MJfj6SmHApg== 146 | dependencies: 147 | "@types/json-schema" "^7.0.3" 148 | "@typescript-eslint/typescript-estree" "2.33.0" 149 | eslint-scope "^5.0.0" 150 | eslint-utils "^2.0.0" 151 | 152 | "@typescript-eslint/parser@^2.33.0": 153 | version "2.33.0" 154 | resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-2.33.0.tgz#395c0ef229ebef883608f8632a34f0acf02b9bdd" 155 | integrity sha512-AUtmwUUhJoH6yrtxZMHbRUEMsC2G6z5NSxg9KsROOGqNXasM71I8P2NihtumlWTUCRld70vqIZ6Pm4E5PAziEA== 156 | dependencies: 157 | "@types/eslint-visitor-keys" "^1.0.0" 158 | "@typescript-eslint/experimental-utils" "2.33.0" 159 | "@typescript-eslint/typescript-estree" "2.33.0" 160 | eslint-visitor-keys "^1.1.0" 161 | 162 | "@typescript-eslint/typescript-estree@2.33.0": 163 | version "2.33.0" 164 | resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-2.33.0.tgz#33504c050ccafd38f397a645d4e9534d2eccbb5c" 165 | integrity sha512-d8rY6/yUxb0+mEwTShCQF2zYQdLlqihukNfG9IUlLYz5y1CH6G/9XYbrxQLq3Z14RNvkCC6oe+OcFlyUpwUbkg== 166 | dependencies: 167 | debug "^4.1.1" 168 | eslint-visitor-keys "^1.1.0" 169 | glob "^7.1.6" 170 | is-glob "^4.0.1" 171 | lodash "^4.17.15" 172 | semver "^7.3.2" 173 | tsutils "^3.17.1" 174 | 175 | abbrev@1: 176 | version "1.1.1" 177 | resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" 178 | integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== 179 | 180 | accepts@~1.3.7: 181 | version "1.3.7" 182 | resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.7.tgz#531bc726517a3b2b41f850021c6cc15eaab507cd" 183 | integrity sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA== 184 | dependencies: 185 | mime-types "~2.1.24" 186 | negotiator "0.6.2" 187 | 188 | acorn-jsx@^5.2.0: 189 | version "5.2.0" 190 | resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.2.0.tgz#4c66069173d6fdd68ed85239fc256226182b2ebe" 191 | integrity sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ== 192 | 193 | acorn@^7.1.1: 194 | version "7.2.0" 195 | resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.2.0.tgz#17ea7e40d7c8640ff54a694c889c26f31704effe" 196 | integrity sha512-apwXVmYVpQ34m/i71vrApRrRKCWQnZZF1+npOD0WV5xZFfwWOmKGQ2RWlfdy9vWITsenisM8M0Qeq8agcFHNiQ== 197 | 198 | ajv@^6.10.0, ajv@^6.10.2: 199 | version "6.12.2" 200 | resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.2.tgz#c629c5eced17baf314437918d2da88c99d5958cd" 201 | integrity sha512-k+V+hzjm5q/Mr8ef/1Y9goCmlsK4I6Sm74teeyGvFk1XrOsbsKLjEdrvny42CZ+a8sXbk8KWpY/bDwS+FLL2UQ== 202 | dependencies: 203 | fast-deep-equal "^3.1.1" 204 | fast-json-stable-stringify "^2.0.0" 205 | json-schema-traverse "^0.4.1" 206 | uri-js "^4.2.2" 207 | 208 | ansi-align@^3.0.0: 209 | version "3.0.0" 210 | resolved "https://registry.yarnpkg.com/ansi-align/-/ansi-align-3.0.0.tgz#b536b371cf687caaef236c18d3e21fe3797467cb" 211 | integrity sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw== 212 | dependencies: 213 | string-width "^3.0.0" 214 | 215 | ansi-escapes@^4.2.1: 216 | version "4.3.1" 217 | resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.1.tgz#a5c47cc43181f1f38ffd7076837700d395522a61" 218 | integrity sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA== 219 | dependencies: 220 | type-fest "^0.11.0" 221 | 222 | ansi-regex@^2.0.0: 223 | version "2.1.1" 224 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" 225 | integrity sha1-w7M6te42DYbg5ijwRorn7yfWVN8= 226 | 227 | ansi-regex@^3.0.0: 228 | version "3.0.0" 229 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998" 230 | integrity sha1-7QMXwyIGT3lGbAKWa922Bas32Zg= 231 | 232 | ansi-regex@^4.1.0: 233 | version "4.1.0" 234 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz#8b9f8f08cf1acb843756a839ca8c7e3168c51997" 235 | integrity sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg== 236 | 237 | ansi-regex@^5.0.0: 238 | version "5.0.0" 239 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75" 240 | integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg== 241 | 242 | ansi-styles@^3.2.0, ansi-styles@^3.2.1: 243 | version "3.2.1" 244 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" 245 | integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== 246 | dependencies: 247 | color-convert "^1.9.0" 248 | 249 | ansi-styles@^4.1.0: 250 | version "4.2.1" 251 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.2.1.tgz#90ae75c424d008d2624c5bf29ead3177ebfcf359" 252 | integrity sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA== 253 | dependencies: 254 | "@types/color-name" "^1.1.1" 255 | color-convert "^2.0.1" 256 | 257 | anymatch@~3.1.1: 258 | version "3.1.1" 259 | resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.1.tgz#c55ecf02185e2469259399310c173ce31233b142" 260 | integrity sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg== 261 | dependencies: 262 | normalize-path "^3.0.0" 263 | picomatch "^2.0.4" 264 | 265 | aproba@^1.0.3: 266 | version "1.2.0" 267 | resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.2.0.tgz#6802e6264efd18c790a1b0d517f0f2627bf2c94a" 268 | integrity sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw== 269 | 270 | are-we-there-yet@~1.1.2: 271 | version "1.1.5" 272 | resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz#4b35c2944f062a8bfcda66410760350fe9ddfc21" 273 | integrity sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w== 274 | dependencies: 275 | delegates "^1.0.0" 276 | readable-stream "^2.0.6" 277 | 278 | arg@^4.1.0: 279 | version "4.1.3" 280 | resolved "https://registry.yarnpkg.com/arg/-/arg-4.1.3.tgz#269fc7ad5b8e42cb63c896d5666017261c144089" 281 | integrity sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA== 282 | 283 | argparse@^1.0.7: 284 | version "1.0.10" 285 | resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" 286 | integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== 287 | dependencies: 288 | sprintf-js "~1.0.2" 289 | 290 | array-differ@^3.0.0: 291 | version "3.0.0" 292 | resolved "https://registry.yarnpkg.com/array-differ/-/array-differ-3.0.0.tgz#3cbb3d0f316810eafcc47624734237d6aee4ae6b" 293 | integrity sha512-THtfYS6KtME/yIAhKjZ2ul7XI96lQGHRputJQHO80LAWQnuGP4iCIN8vdMRboGbIEYBwU33q8Tch1os2+X0kMg== 294 | 295 | array-flatten@1.1.1: 296 | version "1.1.1" 297 | resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" 298 | integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= 299 | 300 | array-union@^2.1.0: 301 | version "2.1.0" 302 | resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" 303 | integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== 304 | 305 | arrify@^2.0.1: 306 | version "2.0.1" 307 | resolved "https://registry.yarnpkg.com/arrify/-/arrify-2.0.1.tgz#c9655e9331e0abcd588d2a7cad7e9956f66701fa" 308 | integrity sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug== 309 | 310 | astral-regex@^1.0.0: 311 | version "1.0.0" 312 | resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-1.0.0.tgz#6c8c3fb827dd43ee3918f27b82782ab7658a6fd9" 313 | integrity sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg== 314 | 315 | aws-sdk@^2.678.0: 316 | version "2.678.0" 317 | resolved "https://registry.yarnpkg.com/aws-sdk/-/aws-sdk-2.678.0.tgz#b16230f4894d40ead50f9e23805c874f4ca62549" 318 | integrity sha512-i8t7+1/C6maQzUYUFRQXPAsUPT0YdpNsf/oHZKmmZrsOX+epnn2jmAGIBTZgUakY8jRrZxCJka+QokUIadUVQg== 319 | dependencies: 320 | buffer "4.9.1" 321 | events "1.1.1" 322 | ieee754 "1.1.13" 323 | jmespath "0.15.0" 324 | querystring "0.2.0" 325 | sax "1.2.1" 326 | url "0.10.3" 327 | uuid "3.3.2" 328 | xml2js "0.4.19" 329 | 330 | balanced-match@^1.0.0: 331 | version "1.0.0" 332 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" 333 | integrity sha1-ibTRmasr7kneFk6gK4nORi1xt2c= 334 | 335 | base64-js@^1.0.2: 336 | version "1.3.1" 337 | resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.3.1.tgz#58ece8cb75dd07e71ed08c736abc5fac4dbf8df1" 338 | integrity sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g== 339 | 340 | binary-extensions@^2.0.0: 341 | version "2.0.0" 342 | resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.0.0.tgz#23c0df14f6a88077f5f986c0d167ec03c3d5537c" 343 | integrity sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow== 344 | 345 | body-parser@1.19.0, body-parser@^1.19.0: 346 | version "1.19.0" 347 | resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.19.0.tgz#96b2709e57c9c4e09a6fd66a8fd979844f69f08a" 348 | integrity sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw== 349 | dependencies: 350 | bytes "3.1.0" 351 | content-type "~1.0.4" 352 | debug "2.6.9" 353 | depd "~1.1.2" 354 | http-errors "1.7.2" 355 | iconv-lite "0.4.24" 356 | on-finished "~2.3.0" 357 | qs "6.7.0" 358 | raw-body "2.4.0" 359 | type-is "~1.6.17" 360 | 361 | boxen@^4.2.0: 362 | version "4.2.0" 363 | resolved "https://registry.yarnpkg.com/boxen/-/boxen-4.2.0.tgz#e411b62357d6d6d36587c8ac3d5d974daa070e64" 364 | integrity sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ== 365 | dependencies: 366 | ansi-align "^3.0.0" 367 | camelcase "^5.3.1" 368 | chalk "^3.0.0" 369 | cli-boxes "^2.2.0" 370 | string-width "^4.1.0" 371 | term-size "^2.1.0" 372 | type-fest "^0.8.1" 373 | widest-line "^3.1.0" 374 | 375 | brace-expansion@^1.1.7: 376 | version "1.1.11" 377 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" 378 | integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== 379 | dependencies: 380 | balanced-match "^1.0.0" 381 | concat-map "0.0.1" 382 | 383 | braces@~3.0.2: 384 | version "3.0.2" 385 | resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" 386 | integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== 387 | dependencies: 388 | fill-range "^7.0.1" 389 | 390 | buffer-from@^1.0.0: 391 | version "1.1.1" 392 | resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef" 393 | integrity sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A== 394 | 395 | buffer@4.9.1: 396 | version "4.9.1" 397 | resolved "https://registry.yarnpkg.com/buffer/-/buffer-4.9.1.tgz#6d1bb601b07a4efced97094132093027c95bc298" 398 | integrity sha1-bRu2AbB6TvztlwlBMgkwJ8lbwpg= 399 | dependencies: 400 | base64-js "^1.0.2" 401 | ieee754 "^1.1.4" 402 | isarray "^1.0.0" 403 | 404 | bytes@3.1.0: 405 | version "3.1.0" 406 | resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.0.tgz#f6cf7933a360e0588fa9fde85651cdc7f805d1f6" 407 | integrity sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg== 408 | 409 | cacheable-request@^6.0.0: 410 | version "6.1.0" 411 | resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-6.1.0.tgz#20ffb8bd162ba4be11e9567d823db651052ca912" 412 | integrity sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg== 413 | dependencies: 414 | clone-response "^1.0.2" 415 | get-stream "^5.1.0" 416 | http-cache-semantics "^4.0.0" 417 | keyv "^3.0.0" 418 | lowercase-keys "^2.0.0" 419 | normalize-url "^4.1.0" 420 | responselike "^1.0.2" 421 | 422 | callsites@^3.0.0: 423 | version "3.1.0" 424 | resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" 425 | integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== 426 | 427 | camelcase@^5.3.1: 428 | version "5.3.1" 429 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" 430 | integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== 431 | 432 | chalk@^2.0.0, chalk@^2.4.2: 433 | version "2.4.2" 434 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" 435 | integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== 436 | dependencies: 437 | ansi-styles "^3.2.1" 438 | escape-string-regexp "^1.0.5" 439 | supports-color "^5.3.0" 440 | 441 | chalk@^3.0.0: 442 | version "3.0.0" 443 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4" 444 | integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg== 445 | dependencies: 446 | ansi-styles "^4.1.0" 447 | supports-color "^7.1.0" 448 | 449 | chalk@^4.0, chalk@^4.0.0: 450 | version "4.0.0" 451 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.0.0.tgz#6e98081ed2d17faab615eb52ac66ec1fe6209e72" 452 | integrity sha512-N9oWFcegS0sFr9oh1oz2d7Npos6vNoWW9HvtCg5N1KRFpUhaAhvTv5Y58g880fZaEYSNm3qDz8SU1UrGvp+n7A== 453 | dependencies: 454 | ansi-styles "^4.1.0" 455 | supports-color "^7.1.0" 456 | 457 | chardet@^0.7.0: 458 | version "0.7.0" 459 | resolved "https://registry.yarnpkg.com/chardet/-/chardet-0.7.0.tgz#90094849f0937f2eedc2425d0d28a9e5f0cbad9e" 460 | integrity sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA== 461 | 462 | chokidar@^3.2.2: 463 | version "3.4.0" 464 | resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.4.0.tgz#b30611423ce376357c765b9b8f904b9fba3c0be8" 465 | integrity sha512-aXAaho2VJtisB/1fg1+3nlLJqGOuewTzQpd/Tz0yTg2R0e4IGtshYvtjowyEumcBv2z+y4+kc75Mz7j5xJskcQ== 466 | dependencies: 467 | anymatch "~3.1.1" 468 | braces "~3.0.2" 469 | glob-parent "~5.1.0" 470 | is-binary-path "~2.1.0" 471 | is-glob "~4.0.1" 472 | normalize-path "~3.0.0" 473 | readdirp "~3.4.0" 474 | optionalDependencies: 475 | fsevents "~2.1.2" 476 | 477 | chownr@^1.1.1: 478 | version "1.1.4" 479 | resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" 480 | integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== 481 | 482 | ci-info@^2.0.0: 483 | version "2.0.0" 484 | resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" 485 | integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== 486 | 487 | cli-boxes@^2.2.0: 488 | version "2.2.0" 489 | resolved "https://registry.yarnpkg.com/cli-boxes/-/cli-boxes-2.2.0.tgz#538ecae8f9c6ca508e3c3c95b453fe93cb4c168d" 490 | integrity sha512-gpaBrMAizVEANOpfZp/EEUixTXDyGt7DFzdK5hU+UbWt/J0lB0w20ncZj59Z9a93xHb9u12zF5BS6i9RKbtg4w== 491 | 492 | cli-cursor@^3.1.0: 493 | version "3.1.0" 494 | resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-3.1.0.tgz#264305a7ae490d1d03bf0c9ba7c925d1753af307" 495 | integrity sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw== 496 | dependencies: 497 | restore-cursor "^3.1.0" 498 | 499 | cli-width@^2.0.0: 500 | version "2.2.1" 501 | resolved "https://registry.yarnpkg.com/cli-width/-/cli-width-2.2.1.tgz#b0433d0b4e9c847ef18868a4ef16fd5fc8271c48" 502 | integrity sha512-GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw== 503 | 504 | clone-response@^1.0.2: 505 | version "1.0.2" 506 | resolved "https://registry.yarnpkg.com/clone-response/-/clone-response-1.0.2.tgz#d1dc973920314df67fbeb94223b4ee350239e96b" 507 | integrity sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws= 508 | dependencies: 509 | mimic-response "^1.0.0" 510 | 511 | code-point-at@^1.0.0: 512 | version "1.1.0" 513 | resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" 514 | integrity sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c= 515 | 516 | color-convert@^1.9.0: 517 | version "1.9.3" 518 | resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" 519 | integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== 520 | dependencies: 521 | color-name "1.1.3" 522 | 523 | color-convert@^2.0.1: 524 | version "2.0.1" 525 | resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" 526 | integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== 527 | dependencies: 528 | color-name "~1.1.4" 529 | 530 | color-name@1.1.3: 531 | version "1.1.3" 532 | resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" 533 | integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU= 534 | 535 | color-name@~1.1.4: 536 | version "1.1.4" 537 | resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" 538 | integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== 539 | 540 | compare-versions@^3.6.0: 541 | version "3.6.0" 542 | resolved "https://registry.yarnpkg.com/compare-versions/-/compare-versions-3.6.0.tgz#1a5689913685e5a87637b8d3ffca75514ec41d62" 543 | integrity sha512-W6Af2Iw1z4CB7q4uU4hv646dW9GQuBM+YpC0UvUCWSD8w90SJjp+ujJuXaEMtAXBtSqGfMPuFOVn4/+FlaqfBA== 544 | 545 | concat-map@0.0.1: 546 | version "0.0.1" 547 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 548 | integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= 549 | 550 | configstore@^5.0.1: 551 | version "5.0.1" 552 | resolved "https://registry.yarnpkg.com/configstore/-/configstore-5.0.1.tgz#d365021b5df4b98cdd187d6a3b0e3f6a7cc5ed96" 553 | integrity sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA== 554 | dependencies: 555 | dot-prop "^5.2.0" 556 | graceful-fs "^4.1.2" 557 | make-dir "^3.0.0" 558 | unique-string "^2.0.0" 559 | write-file-atomic "^3.0.0" 560 | xdg-basedir "^4.0.0" 561 | 562 | console-control-strings@^1.0.0, console-control-strings@~1.1.0: 563 | version "1.1.0" 564 | resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" 565 | integrity sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4= 566 | 567 | content-disposition@0.5.3: 568 | version "0.5.3" 569 | resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.3.tgz#e130caf7e7279087c5616c2007d0485698984fbd" 570 | integrity sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g== 571 | dependencies: 572 | safe-buffer "5.1.2" 573 | 574 | content-type@~1.0.4: 575 | version "1.0.4" 576 | resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" 577 | integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== 578 | 579 | cookie-signature@1.0.6: 580 | version "1.0.6" 581 | resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" 582 | integrity sha1-4wOogrNCzD7oylE6eZmXNNqzriw= 583 | 584 | cookie@0.4.0: 585 | version "0.4.0" 586 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.0.tgz#beb437e7022b3b6d49019d088665303ebe9c14ba" 587 | integrity sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg== 588 | 589 | core-util-is@~1.0.0: 590 | version "1.0.2" 591 | resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" 592 | integrity sha1-tf1UIgqivFq1eqtxQMlAdUUDwac= 593 | 594 | cosmiconfig@^6.0.0: 595 | version "6.0.0" 596 | resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-6.0.0.tgz#da4fee853c52f6b1e6935f41c1a2fc50bd4a9982" 597 | integrity sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg== 598 | dependencies: 599 | "@types/parse-json" "^4.0.0" 600 | import-fresh "^3.1.0" 601 | parse-json "^5.0.0" 602 | path-type "^4.0.0" 603 | yaml "^1.7.2" 604 | 605 | cross-spawn@^7.0.0, cross-spawn@^7.0.2: 606 | version "7.0.2" 607 | resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.2.tgz#d0d7dcfa74e89115c7619f4f721a94e1fdb716d6" 608 | integrity sha512-PD6G8QG3S4FK/XCGFbEQrDqO2AnMMsy0meR7lerlIOHAAbkuavGU/pOqprrlvfTNjvowivTeBsjebAL0NSoMxw== 609 | dependencies: 610 | path-key "^3.1.0" 611 | shebang-command "^2.0.0" 612 | which "^2.0.1" 613 | 614 | crypto-random-string@^2.0.0: 615 | version "2.0.0" 616 | resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-2.0.0.tgz#ef2a7a966ec11083388369baa02ebead229b30d5" 617 | integrity sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA== 618 | 619 | debug@2.6.9, debug@^2.2.0: 620 | version "2.6.9" 621 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" 622 | integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== 623 | dependencies: 624 | ms "2.0.0" 625 | 626 | debug@^3.2.6: 627 | version "3.2.6" 628 | resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.6.tgz#e83d17de16d8a7efb7717edbe5fb10135eee629b" 629 | integrity sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ== 630 | dependencies: 631 | ms "^2.1.1" 632 | 633 | debug@^4.0.1, debug@^4.1.1: 634 | version "4.1.1" 635 | resolved "https://registry.yarnpkg.com/debug/-/debug-4.1.1.tgz#3b72260255109c6b589cee050f1d516139664791" 636 | integrity sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw== 637 | dependencies: 638 | ms "^2.1.1" 639 | 640 | decompress-response@^3.3.0: 641 | version "3.3.0" 642 | resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-3.3.0.tgz#80a4dd323748384bfa248083622aedec982adff3" 643 | integrity sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M= 644 | dependencies: 645 | mimic-response "^1.0.0" 646 | 647 | deep-extend@^0.6.0: 648 | version "0.6.0" 649 | resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" 650 | integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== 651 | 652 | deep-is@^0.1.3: 653 | version "0.1.3" 654 | resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" 655 | integrity sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ= 656 | 657 | defer-to-connect@^1.0.1: 658 | version "1.1.3" 659 | resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-1.1.3.tgz#331ae050c08dcf789f8c83a7b81f0ed94f4ac591" 660 | integrity sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ== 661 | 662 | delegates@^1.0.0: 663 | version "1.0.0" 664 | resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" 665 | integrity sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o= 666 | 667 | depd@~1.1.2: 668 | version "1.1.2" 669 | resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" 670 | integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= 671 | 672 | destroy@~1.0.4: 673 | version "1.0.4" 674 | resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" 675 | integrity sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA= 676 | 677 | detect-libc@^1.0.2: 678 | version "1.0.3" 679 | resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b" 680 | integrity sha1-+hN8S9aY7fVc1c0CrFWfkaTEups= 681 | 682 | diff@^4.0.1: 683 | version "4.0.2" 684 | resolved "https://registry.yarnpkg.com/diff/-/diff-4.0.2.tgz#60f3aecb89d5fae520c11aa19efc2bb982aade7d" 685 | integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== 686 | 687 | doctrine@^3.0.0: 688 | version "3.0.0" 689 | resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" 690 | integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== 691 | dependencies: 692 | esutils "^2.0.2" 693 | 694 | dot-prop@^5.2.0: 695 | version "5.2.0" 696 | resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-5.2.0.tgz#c34ecc29556dc45f1f4c22697b6f4904e0cc4fcb" 697 | integrity sha512-uEUyaDKoSQ1M4Oq8l45hSE26SnTxL6snNnqvK/VWx5wJhmff5z0FUVJDKDanor/6w3kzE3i7XZOk+7wC0EXr1A== 698 | dependencies: 699 | is-obj "^2.0.0" 700 | 701 | duplexer3@^0.1.4: 702 | version "0.1.4" 703 | resolved "https://registry.yarnpkg.com/duplexer3/-/duplexer3-0.1.4.tgz#ee01dd1cac0ed3cbc7fdbea37dc0a8f1ce002ce2" 704 | integrity sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI= 705 | 706 | ee-first@1.1.1: 707 | version "1.1.1" 708 | resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" 709 | integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= 710 | 711 | emoji-regex@^7.0.1: 712 | version "7.0.3" 713 | resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz#933a04052860c85e83c122479c4748a8e4c72156" 714 | integrity sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA== 715 | 716 | emoji-regex@^8.0.0: 717 | version "8.0.0" 718 | resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" 719 | integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== 720 | 721 | encodeurl@~1.0.2: 722 | version "1.0.2" 723 | resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" 724 | integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= 725 | 726 | end-of-stream@^1.1.0: 727 | version "1.4.4" 728 | resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" 729 | integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== 730 | dependencies: 731 | once "^1.4.0" 732 | 733 | error-ex@^1.3.1: 734 | version "1.3.2" 735 | resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" 736 | integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== 737 | dependencies: 738 | is-arrayish "^0.2.1" 739 | 740 | escape-goat@^2.0.0: 741 | version "2.1.1" 742 | resolved "https://registry.yarnpkg.com/escape-goat/-/escape-goat-2.1.1.tgz#1b2dc77003676c457ec760b2dc68edb648188675" 743 | integrity sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q== 744 | 745 | escape-html@~1.0.3: 746 | version "1.0.3" 747 | resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" 748 | integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg= 749 | 750 | escape-string-regexp@^1.0.5: 751 | version "1.0.5" 752 | resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" 753 | integrity sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ= 754 | 755 | eslint-config-prettier@^6.11.0: 756 | version "6.11.0" 757 | resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-6.11.0.tgz#f6d2238c1290d01c859a8b5c1f7d352a0b0da8b1" 758 | integrity sha512-oB8cpLWSAjOVFEJhhyMZh6NOEOtBVziaqdDQ86+qhDHFbZXoRTM7pNSvFRfW/W/L/LrQ38C99J5CGuRBBzBsdA== 759 | dependencies: 760 | get-stdin "^6.0.0" 761 | 762 | eslint-scope@^5.0.0: 763 | version "5.0.0" 764 | resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.0.0.tgz#e87c8887c73e8d1ec84f1ca591645c358bfc8fb9" 765 | integrity sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw== 766 | dependencies: 767 | esrecurse "^4.1.0" 768 | estraverse "^4.1.1" 769 | 770 | eslint-utils@^2.0.0: 771 | version "2.0.0" 772 | resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-2.0.0.tgz#7be1cc70f27a72a76cd14aa698bcabed6890e1cd" 773 | integrity sha512-0HCPuJv+7Wv1bACm8y5/ECVfYdfsAm9xmVb7saeFlxjPYALefjhbYoCkBjPdPzGH8wWyTpAez82Fh3VKYEZ8OA== 774 | dependencies: 775 | eslint-visitor-keys "^1.1.0" 776 | 777 | eslint-visitor-keys@^1.1.0: 778 | version "1.1.0" 779 | resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz#e2a82cea84ff246ad6fb57f9bde5b46621459ec2" 780 | integrity sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A== 781 | 782 | eslint@^7.0.0: 783 | version "7.0.0" 784 | resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.0.0.tgz#c35dfd04a4372110bd78c69a8d79864273919a08" 785 | integrity sha512-qY1cwdOxMONHJfGqw52UOpZDeqXy8xmD0u8CT6jIstil72jkhURC704W8CFyTPDPllz4z4lu0Ql1+07PG/XdIg== 786 | dependencies: 787 | "@babel/code-frame" "^7.0.0" 788 | ajv "^6.10.0" 789 | chalk "^4.0.0" 790 | cross-spawn "^7.0.2" 791 | debug "^4.0.1" 792 | doctrine "^3.0.0" 793 | eslint-scope "^5.0.0" 794 | eslint-utils "^2.0.0" 795 | eslint-visitor-keys "^1.1.0" 796 | espree "^7.0.0" 797 | esquery "^1.2.0" 798 | esutils "^2.0.2" 799 | file-entry-cache "^5.0.1" 800 | functional-red-black-tree "^1.0.1" 801 | glob-parent "^5.0.0" 802 | globals "^12.1.0" 803 | ignore "^4.0.6" 804 | import-fresh "^3.0.0" 805 | imurmurhash "^0.1.4" 806 | inquirer "^7.0.0" 807 | is-glob "^4.0.0" 808 | js-yaml "^3.13.1" 809 | json-stable-stringify-without-jsonify "^1.0.1" 810 | levn "^0.4.1" 811 | lodash "^4.17.14" 812 | minimatch "^3.0.4" 813 | natural-compare "^1.4.0" 814 | optionator "^0.9.1" 815 | progress "^2.0.0" 816 | regexpp "^3.1.0" 817 | semver "^7.2.1" 818 | strip-ansi "^6.0.0" 819 | strip-json-comments "^3.1.0" 820 | table "^5.2.3" 821 | text-table "^0.2.0" 822 | v8-compile-cache "^2.0.3" 823 | 824 | espree@^7.0.0: 825 | version "7.0.0" 826 | resolved "https://registry.yarnpkg.com/espree/-/espree-7.0.0.tgz#8a7a60f218e69f120a842dc24c5a88aa7748a74e" 827 | integrity sha512-/r2XEx5Mw4pgKdyb7GNLQNsu++asx/dltf/CI8RFi9oGHxmQFgvLbc5Op4U6i8Oaj+kdslhJtVlEZeAqH5qOTw== 828 | dependencies: 829 | acorn "^7.1.1" 830 | acorn-jsx "^5.2.0" 831 | eslint-visitor-keys "^1.1.0" 832 | 833 | esprima@^4.0.0: 834 | version "4.0.1" 835 | resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" 836 | integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== 837 | 838 | esquery@^1.2.0: 839 | version "1.3.1" 840 | resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.3.1.tgz#b78b5828aa8e214e29fb74c4d5b752e1c033da57" 841 | integrity sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ== 842 | dependencies: 843 | estraverse "^5.1.0" 844 | 845 | esrecurse@^4.1.0: 846 | version "4.2.1" 847 | resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.2.1.tgz#007a3b9fdbc2b3bb87e4879ea19c92fdbd3942cf" 848 | integrity sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ== 849 | dependencies: 850 | estraverse "^4.1.0" 851 | 852 | estraverse@^4.1.0, estraverse@^4.1.1: 853 | version "4.3.0" 854 | resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" 855 | integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== 856 | 857 | estraverse@^5.1.0: 858 | version "5.1.0" 859 | resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.1.0.tgz#374309d39fd935ae500e7b92e8a6b4c720e59642" 860 | integrity sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw== 861 | 862 | esutils@^2.0.2: 863 | version "2.0.3" 864 | resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" 865 | integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== 866 | 867 | etag@~1.8.1: 868 | version "1.8.1" 869 | resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" 870 | integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= 871 | 872 | events@1.1.1: 873 | version "1.1.1" 874 | resolved "https://registry.yarnpkg.com/events/-/events-1.1.1.tgz#9ebdb7635ad099c70dcc4c2a1f5004288e8bd924" 875 | integrity sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ= 876 | 877 | execa@^2.1.0: 878 | version "2.1.0" 879 | resolved "https://registry.yarnpkg.com/execa/-/execa-2.1.0.tgz#e5d3ecd837d2a60ec50f3da78fd39767747bbe99" 880 | integrity sha512-Y/URAVapfbYy2Xp/gb6A0E7iR8xeqOCXsuuaoMn7A5PzrXUK84E1gyiEfq0wQd/GHA6GsoHWwhNq8anb0mleIw== 881 | dependencies: 882 | cross-spawn "^7.0.0" 883 | get-stream "^5.0.0" 884 | is-stream "^2.0.0" 885 | merge-stream "^2.0.0" 886 | npm-run-path "^3.0.0" 887 | onetime "^5.1.0" 888 | p-finally "^2.0.0" 889 | signal-exit "^3.0.2" 890 | strip-final-newline "^2.0.0" 891 | 892 | express@^4.17.1: 893 | version "4.17.1" 894 | resolved "https://registry.yarnpkg.com/express/-/express-4.17.1.tgz#4491fc38605cf51f8629d39c2b5d026f98a4c134" 895 | integrity sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g== 896 | dependencies: 897 | accepts "~1.3.7" 898 | array-flatten "1.1.1" 899 | body-parser "1.19.0" 900 | content-disposition "0.5.3" 901 | content-type "~1.0.4" 902 | cookie "0.4.0" 903 | cookie-signature "1.0.6" 904 | debug "2.6.9" 905 | depd "~1.1.2" 906 | encodeurl "~1.0.2" 907 | escape-html "~1.0.3" 908 | etag "~1.8.1" 909 | finalhandler "~1.1.2" 910 | fresh "0.5.2" 911 | merge-descriptors "1.0.1" 912 | methods "~1.1.2" 913 | on-finished "~2.3.0" 914 | parseurl "~1.3.3" 915 | path-to-regexp "0.1.7" 916 | proxy-addr "~2.0.5" 917 | qs "6.7.0" 918 | range-parser "~1.2.1" 919 | safe-buffer "5.1.2" 920 | send "0.17.1" 921 | serve-static "1.14.1" 922 | setprototypeof "1.1.1" 923 | statuses "~1.5.0" 924 | type-is "~1.6.18" 925 | utils-merge "1.0.1" 926 | vary "~1.1.2" 927 | 928 | external-editor@^3.0.3: 929 | version "3.1.0" 930 | resolved "https://registry.yarnpkg.com/external-editor/-/external-editor-3.1.0.tgz#cb03f740befae03ea4d283caed2741a83f335495" 931 | integrity sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew== 932 | dependencies: 933 | chardet "^0.7.0" 934 | iconv-lite "^0.4.24" 935 | tmp "^0.0.33" 936 | 937 | fast-deep-equal@^3.1.1: 938 | version "3.1.1" 939 | resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz#545145077c501491e33b15ec408c294376e94ae4" 940 | integrity sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA== 941 | 942 | fast-json-stable-stringify@^2.0.0: 943 | version "2.1.0" 944 | resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" 945 | integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== 946 | 947 | fast-levenshtein@^2.0.6: 948 | version "2.0.6" 949 | resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" 950 | integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc= 951 | 952 | figures@^3.0.0: 953 | version "3.2.0" 954 | resolved "https://registry.yarnpkg.com/figures/-/figures-3.2.0.tgz#625c18bd293c604dc4a8ddb2febf0c88341746af" 955 | integrity sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg== 956 | dependencies: 957 | escape-string-regexp "^1.0.5" 958 | 959 | file-entry-cache@^5.0.1: 960 | version "5.0.1" 961 | resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-5.0.1.tgz#ca0f6efa6dd3d561333fb14515065c2fafdf439c" 962 | integrity sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g== 963 | dependencies: 964 | flat-cache "^2.0.1" 965 | 966 | fill-range@^7.0.1: 967 | version "7.0.1" 968 | resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" 969 | integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== 970 | dependencies: 971 | to-regex-range "^5.0.1" 972 | 973 | finalhandler@~1.1.2: 974 | version "1.1.2" 975 | resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.2.tgz#b7e7d000ffd11938d0fdb053506f6ebabe9f587d" 976 | integrity sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA== 977 | dependencies: 978 | debug "2.6.9" 979 | encodeurl "~1.0.2" 980 | escape-html "~1.0.3" 981 | on-finished "~2.3.0" 982 | parseurl "~1.3.3" 983 | statuses "~1.5.0" 984 | unpipe "~1.0.0" 985 | 986 | find-up@^4.0.0, find-up@^4.1.0: 987 | version "4.1.0" 988 | resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" 989 | integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== 990 | dependencies: 991 | locate-path "^5.0.0" 992 | path-exists "^4.0.0" 993 | 994 | find-versions@^3.2.0: 995 | version "3.2.0" 996 | resolved "https://registry.yarnpkg.com/find-versions/-/find-versions-3.2.0.tgz#10297f98030a786829681690545ef659ed1d254e" 997 | integrity sha512-P8WRou2S+oe222TOCHitLy8zj+SIsVJh52VP4lvXkaFVnOFFdoWv1H1Jjvel1aI6NCFOAaeAVm8qrI0odiLcww== 998 | dependencies: 999 | semver-regex "^2.0.0" 1000 | 1001 | flat-cache@^2.0.1: 1002 | version "2.0.1" 1003 | resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-2.0.1.tgz#5d296d6f04bda44a4630a301413bdbc2ec085ec0" 1004 | integrity sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA== 1005 | dependencies: 1006 | flatted "^2.0.0" 1007 | rimraf "2.6.3" 1008 | write "1.0.3" 1009 | 1010 | flatted@^2.0.0: 1011 | version "2.0.2" 1012 | resolved "https://registry.yarnpkg.com/flatted/-/flatted-2.0.2.tgz#4575b21e2bcee7434aa9be662f4b7b5f9c2b5138" 1013 | integrity sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA== 1014 | 1015 | forwarded@~0.1.2: 1016 | version "0.1.2" 1017 | resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.1.2.tgz#98c23dab1175657b8c0573e8ceccd91b0ff18c84" 1018 | integrity sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ= 1019 | 1020 | fresh@0.5.2: 1021 | version "0.5.2" 1022 | resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" 1023 | integrity sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac= 1024 | 1025 | fs-minipass@^1.2.5: 1026 | version "1.2.7" 1027 | resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-1.2.7.tgz#ccff8570841e7fe4265693da88936c55aed7f7c7" 1028 | integrity sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA== 1029 | dependencies: 1030 | minipass "^2.6.0" 1031 | 1032 | fs.realpath@^1.0.0: 1033 | version "1.0.0" 1034 | resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" 1035 | integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= 1036 | 1037 | fsevents@~2.1.2: 1038 | version "2.1.3" 1039 | resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.1.3.tgz#fb738703ae8d2f9fe900c33836ddebee8b97f23e" 1040 | integrity sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ== 1041 | 1042 | functional-red-black-tree@^1.0.1: 1043 | version "1.0.1" 1044 | resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" 1045 | integrity sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc= 1046 | 1047 | gauge@~2.7.3: 1048 | version "2.7.4" 1049 | resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7" 1050 | integrity sha1-LANAXHU4w51+s3sxcCLjJfsBi/c= 1051 | dependencies: 1052 | aproba "^1.0.3" 1053 | console-control-strings "^1.0.0" 1054 | has-unicode "^2.0.0" 1055 | object-assign "^4.1.0" 1056 | signal-exit "^3.0.0" 1057 | string-width "^1.0.1" 1058 | strip-ansi "^3.0.1" 1059 | wide-align "^1.1.0" 1060 | 1061 | get-stdin@^6.0.0: 1062 | version "6.0.0" 1063 | resolved "https://registry.yarnpkg.com/get-stdin/-/get-stdin-6.0.0.tgz#9e09bf712b360ab9225e812048f71fde9c89657b" 1064 | integrity sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g== 1065 | 1066 | get-stream@^4.1.0: 1067 | version "4.1.0" 1068 | resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz#c1b255575f3dc21d59bfc79cd3d2b46b1c3a54b5" 1069 | integrity sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w== 1070 | dependencies: 1071 | pump "^3.0.0" 1072 | 1073 | get-stream@^5.0.0, get-stream@^5.1.0: 1074 | version "5.1.0" 1075 | resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-5.1.0.tgz#01203cdc92597f9b909067c3e656cc1f4d3c4dc9" 1076 | integrity sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw== 1077 | dependencies: 1078 | pump "^3.0.0" 1079 | 1080 | glob-parent@^5.0.0, glob-parent@~5.1.0: 1081 | version "5.1.1" 1082 | resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.1.tgz#b6c1ef417c4e5663ea498f1c45afac6916bbc229" 1083 | integrity sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ== 1084 | dependencies: 1085 | is-glob "^4.0.1" 1086 | 1087 | glob@^7.1.3, glob@^7.1.6: 1088 | version "7.1.6" 1089 | resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" 1090 | integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== 1091 | dependencies: 1092 | fs.realpath "^1.0.0" 1093 | inflight "^1.0.4" 1094 | inherits "2" 1095 | minimatch "^3.0.4" 1096 | once "^1.3.0" 1097 | path-is-absolute "^1.0.0" 1098 | 1099 | global-dirs@^2.0.1: 1100 | version "2.0.1" 1101 | resolved "https://registry.yarnpkg.com/global-dirs/-/global-dirs-2.0.1.tgz#acdf3bb6685bcd55cb35e8a052266569e9469201" 1102 | integrity sha512-5HqUqdhkEovj2Of/ms3IeS/EekcO54ytHRLV4PEY2rhRwrHXLQjeVEES0Lhka0xwNDtGYn58wyC4s5+MHsOO6A== 1103 | dependencies: 1104 | ini "^1.3.5" 1105 | 1106 | globals@^12.1.0: 1107 | version "12.4.0" 1108 | resolved "https://registry.yarnpkg.com/globals/-/globals-12.4.0.tgz#a18813576a41b00a24a97e7f815918c2e19925f8" 1109 | integrity sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg== 1110 | dependencies: 1111 | type-fest "^0.8.1" 1112 | 1113 | got@^9.6.0: 1114 | version "9.6.0" 1115 | resolved "https://registry.yarnpkg.com/got/-/got-9.6.0.tgz#edf45e7d67f99545705de1f7bbeeeb121765ed85" 1116 | integrity sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q== 1117 | dependencies: 1118 | "@sindresorhus/is" "^0.14.0" 1119 | "@szmarczak/http-timer" "^1.1.2" 1120 | cacheable-request "^6.0.0" 1121 | decompress-response "^3.3.0" 1122 | duplexer3 "^0.1.4" 1123 | get-stream "^4.1.0" 1124 | lowercase-keys "^1.0.1" 1125 | mimic-response "^1.0.1" 1126 | p-cancelable "^1.0.0" 1127 | to-readable-stream "^1.0.0" 1128 | url-parse-lax "^3.0.0" 1129 | 1130 | graceful-fs@^4.1.2: 1131 | version "4.2.4" 1132 | resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.4.tgz#2256bde14d3632958c465ebc96dc467ca07a29fb" 1133 | integrity sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw== 1134 | 1135 | has-flag@^3.0.0: 1136 | version "3.0.0" 1137 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" 1138 | integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= 1139 | 1140 | has-flag@^4.0.0: 1141 | version "4.0.0" 1142 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" 1143 | integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== 1144 | 1145 | has-unicode@^2.0.0: 1146 | version "2.0.1" 1147 | resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" 1148 | integrity sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk= 1149 | 1150 | has-yarn@^2.1.0: 1151 | version "2.1.0" 1152 | resolved "https://registry.yarnpkg.com/has-yarn/-/has-yarn-2.1.0.tgz#137e11354a7b5bf11aa5cb649cf0c6f3ff2b2e77" 1153 | integrity sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw== 1154 | 1155 | http-cache-semantics@^4.0.0: 1156 | version "4.1.0" 1157 | resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" 1158 | integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== 1159 | 1160 | http-errors@1.7.2: 1161 | version "1.7.2" 1162 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.2.tgz#4f5029cf13239f31036e5b2e55292bcfbcc85c8f" 1163 | integrity sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg== 1164 | dependencies: 1165 | depd "~1.1.2" 1166 | inherits "2.0.3" 1167 | setprototypeof "1.1.1" 1168 | statuses ">= 1.5.0 < 2" 1169 | toidentifier "1.0.0" 1170 | 1171 | http-errors@~1.7.2: 1172 | version "1.7.3" 1173 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06" 1174 | integrity sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw== 1175 | dependencies: 1176 | depd "~1.1.2" 1177 | inherits "2.0.4" 1178 | setprototypeof "1.1.1" 1179 | statuses ">= 1.5.0 < 2" 1180 | toidentifier "1.0.0" 1181 | 1182 | husky@^4.2.5: 1183 | version "4.2.5" 1184 | resolved "https://registry.yarnpkg.com/husky/-/husky-4.2.5.tgz#2b4f7622673a71579f901d9885ed448394b5fa36" 1185 | integrity sha512-SYZ95AjKcX7goYVZtVZF2i6XiZcHknw50iXvY7b0MiGoj5RwdgRQNEHdb+gPDPCXKlzwrybjFjkL6FOj8uRhZQ== 1186 | dependencies: 1187 | chalk "^4.0.0" 1188 | ci-info "^2.0.0" 1189 | compare-versions "^3.6.0" 1190 | cosmiconfig "^6.0.0" 1191 | find-versions "^3.2.0" 1192 | opencollective-postinstall "^2.0.2" 1193 | pkg-dir "^4.2.0" 1194 | please-upgrade-node "^3.2.0" 1195 | slash "^3.0.0" 1196 | which-pm-runs "^1.0.0" 1197 | 1198 | iconv-lite@0.4.24, iconv-lite@^0.4.24, iconv-lite@^0.4.4: 1199 | version "0.4.24" 1200 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" 1201 | integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== 1202 | dependencies: 1203 | safer-buffer ">= 2.1.2 < 3" 1204 | 1205 | ieee754@1.1.13, ieee754@^1.1.4: 1206 | version "1.1.13" 1207 | resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.13.tgz#ec168558e95aa181fd87d37f55c32bbcb6708b84" 1208 | integrity sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg== 1209 | 1210 | ignore-by-default@^1.0.1: 1211 | version "1.0.1" 1212 | resolved "https://registry.yarnpkg.com/ignore-by-default/-/ignore-by-default-1.0.1.tgz#48ca6d72f6c6a3af00a9ad4ae6876be3889e2b09" 1213 | integrity sha1-SMptcvbGo68Aqa1K5odr44ieKwk= 1214 | 1215 | ignore-walk@^3.0.1: 1216 | version "3.0.3" 1217 | resolved "https://registry.yarnpkg.com/ignore-walk/-/ignore-walk-3.0.3.tgz#017e2447184bfeade7c238e4aefdd1e8f95b1e37" 1218 | integrity sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw== 1219 | dependencies: 1220 | minimatch "^3.0.4" 1221 | 1222 | ignore@^4.0.6: 1223 | version "4.0.6" 1224 | resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" 1225 | integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== 1226 | 1227 | ignore@^5.1.4: 1228 | version "5.1.4" 1229 | resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.1.4.tgz#84b7b3dbe64552b6ef0eca99f6743dbec6d97adf" 1230 | integrity sha512-MzbUSahkTW1u7JpKKjY7LCARd1fU5W2rLdxlM4kdkayuCwZImjkpluF9CM1aLewYJguPDqewLam18Y6AU69A8A== 1231 | 1232 | import-fresh@^3.0.0, import-fresh@^3.1.0: 1233 | version "3.2.1" 1234 | resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.2.1.tgz#633ff618506e793af5ac91bf48b72677e15cbe66" 1235 | integrity sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ== 1236 | dependencies: 1237 | parent-module "^1.0.0" 1238 | resolve-from "^4.0.0" 1239 | 1240 | import-lazy@^2.1.0: 1241 | version "2.1.0" 1242 | resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-2.1.0.tgz#05698e3d45c88e8d7e9d92cb0584e77f096f3e43" 1243 | integrity sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM= 1244 | 1245 | imurmurhash@^0.1.4: 1246 | version "0.1.4" 1247 | resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" 1248 | integrity sha1-khi5srkoojixPcT7a21XbyMUU+o= 1249 | 1250 | inflight@^1.0.4: 1251 | version "1.0.6" 1252 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 1253 | integrity sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk= 1254 | dependencies: 1255 | once "^1.3.0" 1256 | wrappy "1" 1257 | 1258 | inherits@2, inherits@2.0.4, inherits@~2.0.3: 1259 | version "2.0.4" 1260 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" 1261 | integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== 1262 | 1263 | inherits@2.0.3: 1264 | version "2.0.3" 1265 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" 1266 | integrity sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4= 1267 | 1268 | ini@^1.3.5, ini@~1.3.0: 1269 | version "1.3.5" 1270 | resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.5.tgz#eee25f56db1c9ec6085e0c22778083f596abf927" 1271 | integrity sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw== 1272 | 1273 | inquirer@^7.0.0: 1274 | version "7.1.0" 1275 | resolved "https://registry.yarnpkg.com/inquirer/-/inquirer-7.1.0.tgz#1298a01859883e17c7264b82870ae1034f92dd29" 1276 | integrity sha512-5fJMWEmikSYu0nv/flMc475MhGbB7TSPd/2IpFV4I4rMklboCH2rQjYY5kKiYGHqUF9gvaambupcJFFG9dvReg== 1277 | dependencies: 1278 | ansi-escapes "^4.2.1" 1279 | chalk "^3.0.0" 1280 | cli-cursor "^3.1.0" 1281 | cli-width "^2.0.0" 1282 | external-editor "^3.0.3" 1283 | figures "^3.0.0" 1284 | lodash "^4.17.15" 1285 | mute-stream "0.0.8" 1286 | run-async "^2.4.0" 1287 | rxjs "^6.5.3" 1288 | string-width "^4.1.0" 1289 | strip-ansi "^6.0.0" 1290 | through "^2.3.6" 1291 | 1292 | ipaddr.js@1.9.1: 1293 | version "1.9.1" 1294 | resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" 1295 | integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== 1296 | 1297 | is-arrayish@^0.2.1: 1298 | version "0.2.1" 1299 | resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" 1300 | integrity sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0= 1301 | 1302 | is-binary-path@~2.1.0: 1303 | version "2.1.0" 1304 | resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" 1305 | integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== 1306 | dependencies: 1307 | binary-extensions "^2.0.0" 1308 | 1309 | is-ci@^2.0.0: 1310 | version "2.0.0" 1311 | resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz#6bc6334181810e04b5c22b3d589fdca55026404c" 1312 | integrity sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w== 1313 | dependencies: 1314 | ci-info "^2.0.0" 1315 | 1316 | is-extglob@^2.1.1: 1317 | version "2.1.1" 1318 | resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" 1319 | integrity sha1-qIwCU1eR8C7TfHahueqXc8gz+MI= 1320 | 1321 | is-fullwidth-code-point@^1.0.0: 1322 | version "1.0.0" 1323 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb" 1324 | integrity sha1-754xOG8DGn8NZDr4L95QxFfvAMs= 1325 | dependencies: 1326 | number-is-nan "^1.0.0" 1327 | 1328 | is-fullwidth-code-point@^2.0.0: 1329 | version "2.0.0" 1330 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" 1331 | integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8= 1332 | 1333 | is-fullwidth-code-point@^3.0.0: 1334 | version "3.0.0" 1335 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" 1336 | integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== 1337 | 1338 | is-glob@^4.0.0, is-glob@^4.0.1, is-glob@~4.0.1: 1339 | version "4.0.1" 1340 | resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" 1341 | integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== 1342 | dependencies: 1343 | is-extglob "^2.1.1" 1344 | 1345 | is-installed-globally@^0.3.1: 1346 | version "0.3.2" 1347 | resolved "https://registry.yarnpkg.com/is-installed-globally/-/is-installed-globally-0.3.2.tgz#fd3efa79ee670d1187233182d5b0a1dd00313141" 1348 | integrity sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g== 1349 | dependencies: 1350 | global-dirs "^2.0.1" 1351 | is-path-inside "^3.0.1" 1352 | 1353 | is-npm@^4.0.0: 1354 | version "4.0.0" 1355 | resolved "https://registry.yarnpkg.com/is-npm/-/is-npm-4.0.0.tgz#c90dd8380696df87a7a6d823c20d0b12bbe3c84d" 1356 | integrity sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig== 1357 | 1358 | is-number@^7.0.0: 1359 | version "7.0.0" 1360 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" 1361 | integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== 1362 | 1363 | is-obj@^2.0.0: 1364 | version "2.0.0" 1365 | resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" 1366 | integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== 1367 | 1368 | is-path-inside@^3.0.1: 1369 | version "3.0.2" 1370 | resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.2.tgz#f5220fc82a3e233757291dddc9c5877f2a1f3017" 1371 | integrity sha512-/2UGPSgmtqwo1ktx8NDHjuPwZWmHhO+gj0f93EkhLB5RgW9RZevWYYlIkS6zePc6U2WpOdQYIwHe9YC4DWEBVg== 1372 | 1373 | is-stream@^2.0.0: 1374 | version "2.0.0" 1375 | resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.0.tgz#bde9c32680d6fae04129d6ac9d921ce7815f78e3" 1376 | integrity sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw== 1377 | 1378 | is-typedarray@^1.0.0: 1379 | version "1.0.0" 1380 | resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" 1381 | integrity sha1-5HnICFjfDBsR3dppQPlgEfzaSpo= 1382 | 1383 | is-yarn-global@^0.3.0: 1384 | version "0.3.0" 1385 | resolved "https://registry.yarnpkg.com/is-yarn-global/-/is-yarn-global-0.3.0.tgz#d502d3382590ea3004893746754c89139973e232" 1386 | integrity sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw== 1387 | 1388 | isarray@^1.0.0, isarray@~1.0.0: 1389 | version "1.0.0" 1390 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" 1391 | integrity sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE= 1392 | 1393 | isexe@^2.0.0: 1394 | version "2.0.0" 1395 | resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" 1396 | integrity sha1-6PvzdNxVb/iUehDcsFctYz8s+hA= 1397 | 1398 | jmespath@0.15.0: 1399 | version "0.15.0" 1400 | resolved "https://registry.yarnpkg.com/jmespath/-/jmespath-0.15.0.tgz#a3f222a9aae9f966f5d27c796510e28091764217" 1401 | integrity sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc= 1402 | 1403 | js-tokens@^4.0.0: 1404 | version "4.0.0" 1405 | resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" 1406 | integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== 1407 | 1408 | js-yaml@^3.13.1: 1409 | version "3.13.1" 1410 | resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.13.1.tgz#aff151b30bfdfa8e49e05da22e7415e9dfa37847" 1411 | integrity sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw== 1412 | dependencies: 1413 | argparse "^1.0.7" 1414 | esprima "^4.0.0" 1415 | 1416 | json-buffer@3.0.0: 1417 | version "3.0.0" 1418 | resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.0.tgz#5b1f397afc75d677bde8bcfc0e47e1f9a3d9a898" 1419 | integrity sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg= 1420 | 1421 | json-parse-better-errors@^1.0.1: 1422 | version "1.0.2" 1423 | resolved "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz#bb867cfb3450e69107c131d1c514bab3dc8bcaa9" 1424 | integrity sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw== 1425 | 1426 | json-schema-traverse@^0.4.1: 1427 | version "0.4.1" 1428 | resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" 1429 | integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== 1430 | 1431 | json-stable-stringify-without-jsonify@^1.0.1: 1432 | version "1.0.1" 1433 | resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" 1434 | integrity sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE= 1435 | 1436 | keyv@^3.0.0: 1437 | version "3.1.0" 1438 | resolved "https://registry.yarnpkg.com/keyv/-/keyv-3.1.0.tgz#ecc228486f69991e49e9476485a5be1e8fc5c4d9" 1439 | integrity sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA== 1440 | dependencies: 1441 | json-buffer "3.0.0" 1442 | 1443 | latest-version@^5.0.0: 1444 | version "5.1.0" 1445 | resolved "https://registry.yarnpkg.com/latest-version/-/latest-version-5.1.0.tgz#119dfe908fe38d15dfa43ecd13fa12ec8832face" 1446 | integrity sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA== 1447 | dependencies: 1448 | package-json "^6.3.0" 1449 | 1450 | levn@^0.4.1: 1451 | version "0.4.1" 1452 | resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" 1453 | integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== 1454 | dependencies: 1455 | prelude-ls "^1.2.1" 1456 | type-check "~0.4.0" 1457 | 1458 | lines-and-columns@^1.1.6: 1459 | version "1.1.6" 1460 | resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.1.6.tgz#1c00c743b433cd0a4e80758f7b64a57440d9ff00" 1461 | integrity sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA= 1462 | 1463 | locate-path@^5.0.0: 1464 | version "5.0.0" 1465 | resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0" 1466 | integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== 1467 | dependencies: 1468 | p-locate "^4.1.0" 1469 | 1470 | lodash@^4.17.14, lodash@^4.17.15: 1471 | version "4.17.19" 1472 | resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.19.tgz#e48ddedbe30b3321783c5b4301fbd353bc1e4a4b" 1473 | integrity sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ== 1474 | 1475 | lowercase-keys@^1.0.0, lowercase-keys@^1.0.1: 1476 | version "1.0.1" 1477 | resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-1.0.1.tgz#6f9e30b47084d971a7c820ff15a6c5167b74c26f" 1478 | integrity sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA== 1479 | 1480 | lowercase-keys@^2.0.0: 1481 | version "2.0.0" 1482 | resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-2.0.0.tgz#2603e78b7b4b0006cbca2fbcc8a3202558ac9479" 1483 | integrity sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA== 1484 | 1485 | make-dir@^3.0.0: 1486 | version "3.1.0" 1487 | resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" 1488 | integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== 1489 | dependencies: 1490 | semver "^6.0.0" 1491 | 1492 | make-error@^1.1.1: 1493 | version "1.3.6" 1494 | resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.6.tgz#2eb2e37ea9b67c4891f684a1394799af484cf7a2" 1495 | integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== 1496 | 1497 | media-typer@0.3.0: 1498 | version "0.3.0" 1499 | resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" 1500 | integrity sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g= 1501 | 1502 | merge-descriptors@1.0.1: 1503 | version "1.0.1" 1504 | resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" 1505 | integrity sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E= 1506 | 1507 | merge-stream@^2.0.0: 1508 | version "2.0.0" 1509 | resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" 1510 | integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== 1511 | 1512 | methods@~1.1.2: 1513 | version "1.1.2" 1514 | resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" 1515 | integrity sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4= 1516 | 1517 | mime-db@1.44.0: 1518 | version "1.44.0" 1519 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.44.0.tgz#fa11c5eb0aca1334b4233cb4d52f10c5a6272f92" 1520 | integrity sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg== 1521 | 1522 | mime-types@~2.1.24: 1523 | version "2.1.27" 1524 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.27.tgz#47949f98e279ea53119f5722e0f34e529bec009f" 1525 | integrity sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w== 1526 | dependencies: 1527 | mime-db "1.44.0" 1528 | 1529 | mime@1.6.0: 1530 | version "1.6.0" 1531 | resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" 1532 | integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== 1533 | 1534 | mimic-fn@^2.1.0: 1535 | version "2.1.0" 1536 | resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" 1537 | integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== 1538 | 1539 | mimic-response@^1.0.0, mimic-response@^1.0.1: 1540 | version "1.0.1" 1541 | resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" 1542 | integrity sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ== 1543 | 1544 | minimatch@^3.0.4: 1545 | version "3.0.4" 1546 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" 1547 | integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== 1548 | dependencies: 1549 | brace-expansion "^1.1.7" 1550 | 1551 | minimist@^1.2.0, minimist@^1.2.5: 1552 | version "1.2.5" 1553 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" 1554 | integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== 1555 | 1556 | minipass@^2.6.0, minipass@^2.8.6, minipass@^2.9.0: 1557 | version "2.9.0" 1558 | resolved "https://registry.yarnpkg.com/minipass/-/minipass-2.9.0.tgz#e713762e7d3e32fed803115cf93e04bca9fcc9a6" 1559 | integrity sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg== 1560 | dependencies: 1561 | safe-buffer "^5.1.2" 1562 | yallist "^3.0.0" 1563 | 1564 | minizlib@^1.2.1: 1565 | version "1.3.3" 1566 | resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-1.3.3.tgz#2290de96818a34c29551c8a8d301216bd65a861d" 1567 | integrity sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q== 1568 | dependencies: 1569 | minipass "^2.9.0" 1570 | 1571 | mkdirp@^0.5.0, mkdirp@^0.5.1: 1572 | version "0.5.5" 1573 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz#d91cefd62d1436ca0f41620e251288d420099def" 1574 | integrity sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ== 1575 | dependencies: 1576 | minimist "^1.2.5" 1577 | 1578 | mri@^1.1.4: 1579 | version "1.1.5" 1580 | resolved "https://registry.yarnpkg.com/mri/-/mri-1.1.5.tgz#ce21dba2c69f74a9b7cf8a1ec62307e089e223e0" 1581 | integrity sha512-d2RKzMD4JNyHMbnbWnznPaa8vbdlq/4pNZ3IgdaGrVbBhebBsGUUE/6qorTMYNS6TwuH3ilfOlD2bf4Igh8CKg== 1582 | 1583 | ms@2.0.0: 1584 | version "2.0.0" 1585 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" 1586 | integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= 1587 | 1588 | ms@2.1.1: 1589 | version "2.1.1" 1590 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.1.tgz#30a5864eb3ebb0a66f2ebe6d727af06a09d86e0a" 1591 | integrity sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg== 1592 | 1593 | ms@^2.1.1: 1594 | version "2.1.2" 1595 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" 1596 | integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== 1597 | 1598 | multimatch@^4.0.0: 1599 | version "4.0.0" 1600 | resolved "https://registry.yarnpkg.com/multimatch/-/multimatch-4.0.0.tgz#8c3c0f6e3e8449ada0af3dd29efb491a375191b3" 1601 | integrity sha512-lDmx79y1z6i7RNx0ZGCPq1bzJ6ZoDDKbvh7jxr9SJcWLkShMzXrHbYVpTdnhNM5MXpDUxCQ4DgqVttVXlBgiBQ== 1602 | dependencies: 1603 | "@types/minimatch" "^3.0.3" 1604 | array-differ "^3.0.0" 1605 | array-union "^2.1.0" 1606 | arrify "^2.0.1" 1607 | minimatch "^3.0.4" 1608 | 1609 | mute-stream@0.0.8: 1610 | version "0.0.8" 1611 | resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.8.tgz#1630c42b2251ff81e2a283de96a5497ea92e5e0d" 1612 | integrity sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA== 1613 | 1614 | nan@^2.12.1: 1615 | version "2.14.1" 1616 | resolved "https://registry.yarnpkg.com/nan/-/nan-2.14.1.tgz#d7be34dfa3105b91494c3147089315eff8874b01" 1617 | integrity sha512-isWHgVjnFjh2x2yuJ/tj3JbwoHu3UC2dX5G/88Cm24yB6YopVgxvBObDY7n5xW6ExmFhJpSEQqFPvq9zaXc8Jw== 1618 | 1619 | natural-compare@^1.4.0: 1620 | version "1.4.0" 1621 | resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" 1622 | integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc= 1623 | 1624 | needle@^2.2.1: 1625 | version "2.4.1" 1626 | resolved "https://registry.yarnpkg.com/needle/-/needle-2.4.1.tgz#14af48732463d7475696f937626b1b993247a56a" 1627 | integrity sha512-x/gi6ijr4B7fwl6WYL9FwlCvRQKGlUNvnceho8wxkwXqN8jvVmmmATTmZPRRG7b/yC1eode26C2HO9jl78Du9g== 1628 | dependencies: 1629 | debug "^3.2.6" 1630 | iconv-lite "^0.4.4" 1631 | sax "^1.2.4" 1632 | 1633 | negotiator@0.6.2: 1634 | version "0.6.2" 1635 | resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.2.tgz#feacf7ccf525a77ae9634436a64883ffeca346fb" 1636 | integrity sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw== 1637 | 1638 | node-pre-gyp@^0.11.0: 1639 | version "0.11.0" 1640 | resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz#db1f33215272f692cd38f03238e3e9b47c5dd054" 1641 | integrity sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q== 1642 | dependencies: 1643 | detect-libc "^1.0.2" 1644 | mkdirp "^0.5.1" 1645 | needle "^2.2.1" 1646 | nopt "^4.0.1" 1647 | npm-packlist "^1.1.6" 1648 | npmlog "^4.0.2" 1649 | rc "^1.2.7" 1650 | rimraf "^2.6.1" 1651 | semver "^5.3.0" 1652 | tar "^4" 1653 | 1654 | nodemon@^2.0.4: 1655 | version "2.0.4" 1656 | resolved "https://registry.yarnpkg.com/nodemon/-/nodemon-2.0.4.tgz#55b09319eb488d6394aa9818148c0c2d1c04c416" 1657 | integrity sha512-Ltced+hIfTmaS28Zjv1BM552oQ3dbwPqI4+zI0SLgq+wpJhSyqgYude/aZa/3i31VCQWMfXJVxvu86abcam3uQ== 1658 | dependencies: 1659 | chokidar "^3.2.2" 1660 | debug "^3.2.6" 1661 | ignore-by-default "^1.0.1" 1662 | minimatch "^3.0.4" 1663 | pstree.remy "^1.1.7" 1664 | semver "^5.7.1" 1665 | supports-color "^5.5.0" 1666 | touch "^3.1.0" 1667 | undefsafe "^2.0.2" 1668 | update-notifier "^4.0.0" 1669 | 1670 | nopt@^4.0.1: 1671 | version "4.0.3" 1672 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-4.0.3.tgz#a375cad9d02fd921278d954c2254d5aa57e15e48" 1673 | integrity sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg== 1674 | dependencies: 1675 | abbrev "1" 1676 | osenv "^0.1.4" 1677 | 1678 | nopt@~1.0.10: 1679 | version "1.0.10" 1680 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-1.0.10.tgz#6ddd21bd2a31417b92727dd585f8a6f37608ebee" 1681 | integrity sha1-bd0hvSoxQXuScn3Vhfim83YI6+4= 1682 | dependencies: 1683 | abbrev "1" 1684 | 1685 | normalize-path@^3.0.0, normalize-path@~3.0.0: 1686 | version "3.0.0" 1687 | resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" 1688 | integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== 1689 | 1690 | normalize-url@^4.1.0: 1691 | version "4.5.0" 1692 | resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.0.tgz#453354087e6ca96957bd8f5baf753f5982142129" 1693 | integrity sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ== 1694 | 1695 | npm-bundled@^1.0.1: 1696 | version "1.1.1" 1697 | resolved "https://registry.yarnpkg.com/npm-bundled/-/npm-bundled-1.1.1.tgz#1edd570865a94cdb1bc8220775e29466c9fb234b" 1698 | integrity sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA== 1699 | dependencies: 1700 | npm-normalize-package-bin "^1.0.1" 1701 | 1702 | npm-normalize-package-bin@^1.0.1: 1703 | version "1.0.1" 1704 | resolved "https://registry.yarnpkg.com/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz#6e79a41f23fd235c0623218228da7d9c23b8f6e2" 1705 | integrity sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA== 1706 | 1707 | npm-packlist@^1.1.6: 1708 | version "1.4.8" 1709 | resolved "https://registry.yarnpkg.com/npm-packlist/-/npm-packlist-1.4.8.tgz#56ee6cc135b9f98ad3d51c1c95da22bbb9b2ef3e" 1710 | integrity sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A== 1711 | dependencies: 1712 | ignore-walk "^3.0.1" 1713 | npm-bundled "^1.0.1" 1714 | npm-normalize-package-bin "^1.0.1" 1715 | 1716 | npm-run-path@^3.0.0: 1717 | version "3.1.0" 1718 | resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-3.1.0.tgz#7f91be317f6a466efed3c9f2980ad8a4ee8b0fa5" 1719 | integrity sha512-Dbl4A/VfiVGLgQv29URL9xshU8XDY1GeLy+fsaZ1AA8JDSfjvr5P5+pzRbWqRSBxk6/DW7MIh8lTM/PaGnP2kg== 1720 | dependencies: 1721 | path-key "^3.0.0" 1722 | 1723 | npmlog@^4.0.2: 1724 | version "4.1.2" 1725 | resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-4.1.2.tgz#08a7f2a8bf734604779a9efa4ad5cc717abb954b" 1726 | integrity sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg== 1727 | dependencies: 1728 | are-we-there-yet "~1.1.2" 1729 | console-control-strings "~1.1.0" 1730 | gauge "~2.7.3" 1731 | set-blocking "~2.0.0" 1732 | 1733 | number-is-nan@^1.0.0: 1734 | version "1.0.1" 1735 | resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" 1736 | integrity sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0= 1737 | 1738 | object-assign@^4.1.0: 1739 | version "4.1.1" 1740 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 1741 | integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= 1742 | 1743 | on-finished@~2.3.0: 1744 | version "2.3.0" 1745 | resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" 1746 | integrity sha1-IPEzZIGwg811M3mSoWlxqi2QaUc= 1747 | dependencies: 1748 | ee-first "1.1.1" 1749 | 1750 | once@^1.3.0, once@^1.3.1, once@^1.4.0: 1751 | version "1.4.0" 1752 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 1753 | integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= 1754 | dependencies: 1755 | wrappy "1" 1756 | 1757 | onetime@^5.1.0: 1758 | version "5.1.0" 1759 | resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.0.tgz#fff0f3c91617fe62bb50189636e99ac8a6df7be5" 1760 | integrity sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q== 1761 | dependencies: 1762 | mimic-fn "^2.1.0" 1763 | 1764 | opencollective-postinstall@^2.0.2: 1765 | version "2.0.2" 1766 | resolved "https://registry.yarnpkg.com/opencollective-postinstall/-/opencollective-postinstall-2.0.2.tgz#5657f1bede69b6e33a45939b061eb53d3c6c3a89" 1767 | integrity sha512-pVOEP16TrAO2/fjej1IdOyupJY8KDUM1CvsaScRbw6oddvpQoOfGk4ywha0HKKVAD6RkW4x6Q+tNBwhf3Bgpuw== 1768 | 1769 | optionator@^0.9.1: 1770 | version "0.9.1" 1771 | resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" 1772 | integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== 1773 | dependencies: 1774 | deep-is "^0.1.3" 1775 | fast-levenshtein "^2.0.6" 1776 | levn "^0.4.1" 1777 | prelude-ls "^1.2.1" 1778 | type-check "^0.4.0" 1779 | word-wrap "^1.2.3" 1780 | 1781 | os-homedir@^1.0.0: 1782 | version "1.0.2" 1783 | resolved "https://registry.yarnpkg.com/os-homedir/-/os-homedir-1.0.2.tgz#ffbc4988336e0e833de0c168c7ef152121aa7fb3" 1784 | integrity sha1-/7xJiDNuDoM94MFox+8VISGqf7M= 1785 | 1786 | os-tmpdir@^1.0.0, os-tmpdir@~1.0.2: 1787 | version "1.0.2" 1788 | resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" 1789 | integrity sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ= 1790 | 1791 | osenv@^0.1.4: 1792 | version "0.1.5" 1793 | resolved "https://registry.yarnpkg.com/osenv/-/osenv-0.1.5.tgz#85cdfafaeb28e8677f416e287592b5f3f49ea410" 1794 | integrity sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g== 1795 | dependencies: 1796 | os-homedir "^1.0.0" 1797 | os-tmpdir "^1.0.0" 1798 | 1799 | p-cancelable@^1.0.0: 1800 | version "1.1.0" 1801 | resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-1.1.0.tgz#d078d15a3af409220c886f1d9a0ca2e441ab26cc" 1802 | integrity sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw== 1803 | 1804 | p-finally@^2.0.0: 1805 | version "2.0.1" 1806 | resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-2.0.1.tgz#bd6fcaa9c559a096b680806f4d657b3f0f240561" 1807 | integrity sha512-vpm09aKwq6H9phqRQzecoDpD8TmVyGw70qmWlyq5onxY7tqyTTFVvxMykxQSQKILBSFlbXpypIw2T1Ml7+DDtw== 1808 | 1809 | p-limit@^2.2.0: 1810 | version "2.3.0" 1811 | resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" 1812 | integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== 1813 | dependencies: 1814 | p-try "^2.0.0" 1815 | 1816 | p-locate@^4.1.0: 1817 | version "4.1.0" 1818 | resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" 1819 | integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== 1820 | dependencies: 1821 | p-limit "^2.2.0" 1822 | 1823 | p-try@^2.0.0: 1824 | version "2.2.0" 1825 | resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" 1826 | integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== 1827 | 1828 | package-json@^6.3.0: 1829 | version "6.5.0" 1830 | resolved "https://registry.yarnpkg.com/package-json/-/package-json-6.5.0.tgz#6feedaca35e75725876d0b0e64974697fed145b0" 1831 | integrity sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ== 1832 | dependencies: 1833 | got "^9.6.0" 1834 | registry-auth-token "^4.0.0" 1835 | registry-url "^5.0.0" 1836 | semver "^6.2.0" 1837 | 1838 | parent-module@^1.0.0: 1839 | version "1.0.1" 1840 | resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" 1841 | integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== 1842 | dependencies: 1843 | callsites "^3.0.0" 1844 | 1845 | parse-json@^5.0.0: 1846 | version "5.0.0" 1847 | resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.0.0.tgz#73e5114c986d143efa3712d4ea24db9a4266f60f" 1848 | integrity sha512-OOY5b7PAEFV0E2Fir1KOkxchnZNCdowAJgQ5NuxjpBKTRP3pQhwkrkxqQjeoKJ+fO7bCpmIZaogI4eZGDMEGOw== 1849 | dependencies: 1850 | "@babel/code-frame" "^7.0.0" 1851 | error-ex "^1.3.1" 1852 | json-parse-better-errors "^1.0.1" 1853 | lines-and-columns "^1.1.6" 1854 | 1855 | parseurl@~1.3.3: 1856 | version "1.3.3" 1857 | resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" 1858 | integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== 1859 | 1860 | path-exists@^4.0.0: 1861 | version "4.0.0" 1862 | resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" 1863 | integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== 1864 | 1865 | path-is-absolute@^1.0.0: 1866 | version "1.0.1" 1867 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 1868 | integrity sha1-F0uSaHNVNP+8es5r9TpanhtcX18= 1869 | 1870 | path-key@^3.0.0, path-key@^3.1.0: 1871 | version "3.1.1" 1872 | resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" 1873 | integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== 1874 | 1875 | path-to-regexp@0.1.7: 1876 | version "0.1.7" 1877 | resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" 1878 | integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= 1879 | 1880 | path-type@^4.0.0: 1881 | version "4.0.0" 1882 | resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" 1883 | integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== 1884 | 1885 | picomatch@^2.0.4, picomatch@^2.2.1: 1886 | version "2.2.2" 1887 | resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" 1888 | integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== 1889 | 1890 | pkg-dir@^4.2.0: 1891 | version "4.2.0" 1892 | resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" 1893 | integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== 1894 | dependencies: 1895 | find-up "^4.0.0" 1896 | 1897 | please-upgrade-node@^3.2.0: 1898 | version "3.2.0" 1899 | resolved "https://registry.yarnpkg.com/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz#aeddd3f994c933e4ad98b99d9a556efa0e2fe942" 1900 | integrity sha512-gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg== 1901 | dependencies: 1902 | semver-compare "^1.0.0" 1903 | 1904 | prelude-ls@^1.2.1: 1905 | version "1.2.1" 1906 | resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" 1907 | integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== 1908 | 1909 | prepend-http@^2.0.0: 1910 | version "2.0.0" 1911 | resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-2.0.0.tgz#e92434bfa5ea8c19f41cdfd401d741a3c819d897" 1912 | integrity sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc= 1913 | 1914 | prettier@^2.0.5: 1915 | version "2.0.5" 1916 | resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.0.5.tgz#d6d56282455243f2f92cc1716692c08aa31522d4" 1917 | integrity sha512-7PtVymN48hGcO4fGjybyBSIWDsLU4H4XlvOHfq91pz9kkGlonzwTfYkaIEwiRg/dAJF9YlbsduBAgtYLi+8cFg== 1918 | 1919 | pretty-quick@^2.0.1: 1920 | version "2.0.1" 1921 | resolved "https://registry.yarnpkg.com/pretty-quick/-/pretty-quick-2.0.1.tgz#417ee605ade98ecc686e72f63b5d28a2c35b43e9" 1922 | integrity sha512-y7bJt77XadjUr+P1uKqZxFWLddvj3SKY6EU4BuQtMxmmEFSMpbN132pUWdSG1g1mtUfO0noBvn7wBf0BVeomHg== 1923 | dependencies: 1924 | chalk "^2.4.2" 1925 | execa "^2.1.0" 1926 | find-up "^4.1.0" 1927 | ignore "^5.1.4" 1928 | mri "^1.1.4" 1929 | multimatch "^4.0.0" 1930 | 1931 | process-nextick-args@~2.0.0: 1932 | version "2.0.1" 1933 | resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" 1934 | integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== 1935 | 1936 | progress@^2.0.0: 1937 | version "2.0.3" 1938 | resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" 1939 | integrity sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA== 1940 | 1941 | proxy-addr@~2.0.5: 1942 | version "2.0.6" 1943 | resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.6.tgz#fdc2336505447d3f2f2c638ed272caf614bbb2bf" 1944 | integrity sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw== 1945 | dependencies: 1946 | forwarded "~0.1.2" 1947 | ipaddr.js "1.9.1" 1948 | 1949 | pstree.remy@^1.1.7: 1950 | version "1.1.8" 1951 | resolved "https://registry.yarnpkg.com/pstree.remy/-/pstree.remy-1.1.8.tgz#c242224f4a67c21f686839bbdb4ac282b8373d3a" 1952 | integrity sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w== 1953 | 1954 | pump@^3.0.0: 1955 | version "3.0.0" 1956 | resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" 1957 | integrity sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww== 1958 | dependencies: 1959 | end-of-stream "^1.1.0" 1960 | once "^1.3.1" 1961 | 1962 | punycode@1.3.2: 1963 | version "1.3.2" 1964 | resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d" 1965 | integrity sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0= 1966 | 1967 | punycode@^2.1.0: 1968 | version "2.1.1" 1969 | resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" 1970 | integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== 1971 | 1972 | pupa@^2.0.1: 1973 | version "2.0.1" 1974 | resolved "https://registry.yarnpkg.com/pupa/-/pupa-2.0.1.tgz#dbdc9ff48ffbea4a26a069b6f9f7abb051008726" 1975 | integrity sha512-hEJH0s8PXLY/cdXh66tNEQGndDrIKNqNC5xmrysZy3i5C3oEoLna7YAOad+7u125+zH1HNXUmGEkrhb3c2VriA== 1976 | dependencies: 1977 | escape-goat "^2.0.0" 1978 | 1979 | qs@6.7.0: 1980 | version "6.7.0" 1981 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.7.0.tgz#41dc1a015e3d581f1621776be31afb2876a9b1bc" 1982 | integrity sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ== 1983 | 1984 | querystring@0.2.0: 1985 | version "0.2.0" 1986 | resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.0.tgz#b209849203bb25df820da756e747005878521620" 1987 | integrity sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA= 1988 | 1989 | range-parser@~1.2.1: 1990 | version "1.2.1" 1991 | resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" 1992 | integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== 1993 | 1994 | raw-body@2.4.0: 1995 | version "2.4.0" 1996 | resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.0.tgz#a1ce6fb9c9bc356ca52e89256ab59059e13d0332" 1997 | integrity sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q== 1998 | dependencies: 1999 | bytes "3.1.0" 2000 | http-errors "1.7.2" 2001 | iconv-lite "0.4.24" 2002 | unpipe "1.0.0" 2003 | 2004 | rc@^1.2.7, rc@^1.2.8: 2005 | version "1.2.8" 2006 | resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" 2007 | integrity sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw== 2008 | dependencies: 2009 | deep-extend "^0.6.0" 2010 | ini "~1.3.0" 2011 | minimist "^1.2.0" 2012 | strip-json-comments "~2.0.1" 2013 | 2014 | readable-stream@^2.0.6: 2015 | version "2.3.7" 2016 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" 2017 | integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== 2018 | dependencies: 2019 | core-util-is "~1.0.0" 2020 | inherits "~2.0.3" 2021 | isarray "~1.0.0" 2022 | process-nextick-args "~2.0.0" 2023 | safe-buffer "~5.1.1" 2024 | string_decoder "~1.1.1" 2025 | util-deprecate "~1.0.1" 2026 | 2027 | readdirp@~3.4.0: 2028 | version "3.4.0" 2029 | resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.4.0.tgz#9fdccdf9e9155805449221ac645e8303ab5b9ada" 2030 | integrity sha512-0xe001vZBnJEK+uKcj8qOhyAKPzIT+gStxWr3LCB0DwcXR5NZJ3IaC+yGnHCYzB/S7ov3m3EEbZI2zeNvX+hGQ== 2031 | dependencies: 2032 | picomatch "^2.2.1" 2033 | 2034 | regexpp@^3.0.0, regexpp@^3.1.0: 2035 | version "3.1.0" 2036 | resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.1.0.tgz#206d0ad0a5648cffbdb8ae46438f3dc51c9f78e2" 2037 | integrity sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q== 2038 | 2039 | registry-auth-token@^4.0.0: 2040 | version "4.1.1" 2041 | resolved "https://registry.yarnpkg.com/registry-auth-token/-/registry-auth-token-4.1.1.tgz#40a33be1e82539460f94328b0f7f0f84c16d9479" 2042 | integrity sha512-9bKS7nTl9+/A1s7tnPeGrUpRcVY+LUh7bfFgzpndALdPfXQBfQV77rQVtqgUV3ti4vc/Ik81Ex8UJDWDQ12zQA== 2043 | dependencies: 2044 | rc "^1.2.8" 2045 | 2046 | registry-url@^5.0.0: 2047 | version "5.1.0" 2048 | resolved "https://registry.yarnpkg.com/registry-url/-/registry-url-5.1.0.tgz#e98334b50d5434b81136b44ec638d9c2009c5009" 2049 | integrity sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw== 2050 | dependencies: 2051 | rc "^1.2.8" 2052 | 2053 | resolve-from@^4.0.0: 2054 | version "4.0.0" 2055 | resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" 2056 | integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== 2057 | 2058 | responselike@^1.0.2: 2059 | version "1.0.2" 2060 | resolved "https://registry.yarnpkg.com/responselike/-/responselike-1.0.2.tgz#918720ef3b631c5642be068f15ade5a46f4ba1e7" 2061 | integrity sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec= 2062 | dependencies: 2063 | lowercase-keys "^1.0.0" 2064 | 2065 | restore-cursor@^3.1.0: 2066 | version "3.1.0" 2067 | resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-3.1.0.tgz#39f67c54b3a7a58cea5236d95cf0034239631f7e" 2068 | integrity sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA== 2069 | dependencies: 2070 | onetime "^5.1.0" 2071 | signal-exit "^3.0.2" 2072 | 2073 | rimraf@2.6.3: 2074 | version "2.6.3" 2075 | resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.6.3.tgz#b2d104fe0d8fb27cf9e0a1cda8262dd3833c6cab" 2076 | integrity sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA== 2077 | dependencies: 2078 | glob "^7.1.3" 2079 | 2080 | rimraf@^2.6.1: 2081 | version "2.7.1" 2082 | resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" 2083 | integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== 2084 | dependencies: 2085 | glob "^7.1.3" 2086 | 2087 | run-async@^2.4.0: 2088 | version "2.4.1" 2089 | resolved "https://registry.yarnpkg.com/run-async/-/run-async-2.4.1.tgz#8440eccf99ea3e70bd409d49aab88e10c189a455" 2090 | integrity sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ== 2091 | 2092 | rxjs@^6.5.3: 2093 | version "6.5.5" 2094 | resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-6.5.5.tgz#c5c884e3094c8cfee31bf27eb87e54ccfc87f9ec" 2095 | integrity sha512-WfQI+1gohdf0Dai/Bbmk5L5ItH5tYqm3ki2c5GdWhKjalzjg93N3avFjVStyZZz+A2Em+ZxKH5bNghw9UeylGQ== 2096 | dependencies: 2097 | tslib "^1.9.0" 2098 | 2099 | safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: 2100 | version "5.1.2" 2101 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" 2102 | integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== 2103 | 2104 | safe-buffer@^5.1.2: 2105 | version "5.2.1" 2106 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" 2107 | integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== 2108 | 2109 | "safer-buffer@>= 2.1.2 < 3": 2110 | version "2.1.2" 2111 | resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" 2112 | integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== 2113 | 2114 | sax@1.2.1: 2115 | version "1.2.1" 2116 | resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.1.tgz#7b8e656190b228e81a66aea748480d828cd2d37a" 2117 | integrity sha1-e45lYZCyKOgaZq6nSEgNgozS03o= 2118 | 2119 | sax@>=0.6.0, sax@^1.2.4: 2120 | version "1.2.4" 2121 | resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" 2122 | integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== 2123 | 2124 | semver-compare@^1.0.0: 2125 | version "1.0.0" 2126 | resolved "https://registry.yarnpkg.com/semver-compare/-/semver-compare-1.0.0.tgz#0dee216a1c941ab37e9efb1788f6afc5ff5537fc" 2127 | integrity sha1-De4hahyUGrN+nvsXiPavxf9VN/w= 2128 | 2129 | semver-diff@^3.1.1: 2130 | version "3.1.1" 2131 | resolved "https://registry.yarnpkg.com/semver-diff/-/semver-diff-3.1.1.tgz#05f77ce59f325e00e2706afd67bb506ddb1ca32b" 2132 | integrity sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg== 2133 | dependencies: 2134 | semver "^6.3.0" 2135 | 2136 | semver-regex@^2.0.0: 2137 | version "2.0.0" 2138 | resolved "https://registry.yarnpkg.com/semver-regex/-/semver-regex-2.0.0.tgz#a93c2c5844539a770233379107b38c7b4ac9d338" 2139 | integrity sha512-mUdIBBvdn0PLOeP3TEkMH7HHeUP3GjsXCwKarjv/kGmUFOYg1VqEemKhoQpWMu6X2I8kHeuVdGibLGkVK+/5Qw== 2140 | 2141 | semver@^5.3.0, semver@^5.7.1: 2142 | version "5.7.1" 2143 | resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" 2144 | integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== 2145 | 2146 | semver@^6.0.0, semver@^6.2.0, semver@^6.3.0: 2147 | version "6.3.0" 2148 | resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" 2149 | integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== 2150 | 2151 | semver@^7.2.1, semver@^7.3.2: 2152 | version "7.3.2" 2153 | resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.2.tgz#604962b052b81ed0786aae84389ffba70ffd3938" 2154 | integrity sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ== 2155 | 2156 | send@0.17.1: 2157 | version "0.17.1" 2158 | resolved "https://registry.yarnpkg.com/send/-/send-0.17.1.tgz#c1d8b059f7900f7466dd4938bdc44e11ddb376c8" 2159 | integrity sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg== 2160 | dependencies: 2161 | debug "2.6.9" 2162 | depd "~1.1.2" 2163 | destroy "~1.0.4" 2164 | encodeurl "~1.0.2" 2165 | escape-html "~1.0.3" 2166 | etag "~1.8.1" 2167 | fresh "0.5.2" 2168 | http-errors "~1.7.2" 2169 | mime "1.6.0" 2170 | ms "2.1.1" 2171 | on-finished "~2.3.0" 2172 | range-parser "~1.2.1" 2173 | statuses "~1.5.0" 2174 | 2175 | serve-static@1.14.1: 2176 | version "1.14.1" 2177 | resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.14.1.tgz#666e636dc4f010f7ef29970a88a674320898b2f9" 2178 | integrity sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg== 2179 | dependencies: 2180 | encodeurl "~1.0.2" 2181 | escape-html "~1.0.3" 2182 | parseurl "~1.3.3" 2183 | send "0.17.1" 2184 | 2185 | set-blocking@~2.0.0: 2186 | version "2.0.0" 2187 | resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" 2188 | integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc= 2189 | 2190 | setprototypeof@1.1.1: 2191 | version "1.1.1" 2192 | resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.1.tgz#7e95acb24aa92f5885e0abef5ba131330d4ae683" 2193 | integrity sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw== 2194 | 2195 | shebang-command@^2.0.0: 2196 | version "2.0.0" 2197 | resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" 2198 | integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== 2199 | dependencies: 2200 | shebang-regex "^3.0.0" 2201 | 2202 | shebang-regex@^3.0.0: 2203 | version "3.0.0" 2204 | resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" 2205 | integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== 2206 | 2207 | signal-exit@^3.0.0, signal-exit@^3.0.2: 2208 | version "3.0.3" 2209 | resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz#a1410c2edd8f077b08b4e253c8eacfcaf057461c" 2210 | integrity sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA== 2211 | 2212 | slash@^3.0.0: 2213 | version "3.0.0" 2214 | resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" 2215 | integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== 2216 | 2217 | slice-ansi@^2.1.0: 2218 | version "2.1.0" 2219 | resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-2.1.0.tgz#cacd7693461a637a5788d92a7dd4fba068e81636" 2220 | integrity sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ== 2221 | dependencies: 2222 | ansi-styles "^3.2.0" 2223 | astral-regex "^1.0.0" 2224 | is-fullwidth-code-point "^2.0.0" 2225 | 2226 | source-map-support@^0.5.17: 2227 | version "0.5.19" 2228 | resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.19.tgz#a98b62f86dcaf4f67399648c085291ab9e8fed61" 2229 | integrity sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw== 2230 | dependencies: 2231 | buffer-from "^1.0.0" 2232 | source-map "^0.6.0" 2233 | 2234 | source-map@^0.6.0: 2235 | version "0.6.1" 2236 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" 2237 | integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== 2238 | 2239 | sprintf-js@~1.0.2: 2240 | version "1.0.3" 2241 | resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" 2242 | integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw= 2243 | 2244 | sqlite3@^4.1.1: 2245 | version "4.2.0" 2246 | resolved "https://registry.yarnpkg.com/sqlite3/-/sqlite3-4.2.0.tgz#49026d665e9fc4f922e56fb9711ba5b4c85c4901" 2247 | integrity sha512-roEOz41hxui2Q7uYnWsjMOTry6TcNUNmp8audCx18gF10P2NknwdpF+E+HKvz/F2NvPKGGBF4NGc+ZPQ+AABwg== 2248 | dependencies: 2249 | nan "^2.12.1" 2250 | node-pre-gyp "^0.11.0" 2251 | 2252 | "statuses@>= 1.5.0 < 2", statuses@~1.5.0: 2253 | version "1.5.0" 2254 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" 2255 | integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= 2256 | 2257 | string-width@^1.0.1: 2258 | version "1.0.2" 2259 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" 2260 | integrity sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M= 2261 | dependencies: 2262 | code-point-at "^1.0.0" 2263 | is-fullwidth-code-point "^1.0.0" 2264 | strip-ansi "^3.0.0" 2265 | 2266 | "string-width@^1.0.2 || 2": 2267 | version "2.1.1" 2268 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" 2269 | integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== 2270 | dependencies: 2271 | is-fullwidth-code-point "^2.0.0" 2272 | strip-ansi "^4.0.0" 2273 | 2274 | string-width@^3.0.0: 2275 | version "3.1.0" 2276 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz#22767be21b62af1081574306f69ac51b62203961" 2277 | integrity sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w== 2278 | dependencies: 2279 | emoji-regex "^7.0.1" 2280 | is-fullwidth-code-point "^2.0.0" 2281 | strip-ansi "^5.1.0" 2282 | 2283 | string-width@^4.0.0, string-width@^4.1.0: 2284 | version "4.2.0" 2285 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.0.tgz#952182c46cc7b2c313d1596e623992bd163b72b5" 2286 | integrity sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg== 2287 | dependencies: 2288 | emoji-regex "^8.0.0" 2289 | is-fullwidth-code-point "^3.0.0" 2290 | strip-ansi "^6.0.0" 2291 | 2292 | string_decoder@~1.1.1: 2293 | version "1.1.1" 2294 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" 2295 | integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== 2296 | dependencies: 2297 | safe-buffer "~5.1.0" 2298 | 2299 | strip-ansi@^3.0.0, strip-ansi@^3.0.1: 2300 | version "3.0.1" 2301 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" 2302 | integrity sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8= 2303 | dependencies: 2304 | ansi-regex "^2.0.0" 2305 | 2306 | strip-ansi@^4.0.0: 2307 | version "4.0.0" 2308 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" 2309 | integrity sha1-qEeQIusaw2iocTibY1JixQXuNo8= 2310 | dependencies: 2311 | ansi-regex "^3.0.0" 2312 | 2313 | strip-ansi@^5.1.0: 2314 | version "5.2.0" 2315 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" 2316 | integrity sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA== 2317 | dependencies: 2318 | ansi-regex "^4.1.0" 2319 | 2320 | strip-ansi@^6.0.0: 2321 | version "6.0.0" 2322 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" 2323 | integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w== 2324 | dependencies: 2325 | ansi-regex "^5.0.0" 2326 | 2327 | strip-final-newline@^2.0.0: 2328 | version "2.0.0" 2329 | resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" 2330 | integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== 2331 | 2332 | strip-json-comments@^3.1.0: 2333 | version "3.1.0" 2334 | resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.0.tgz#7638d31422129ecf4457440009fba03f9f9ac180" 2335 | integrity sha512-e6/d0eBu7gHtdCqFt0xJr642LdToM5/cN4Qb9DbHjVx1CP5RyeM+zH7pbecEmDv/lBqb0QH+6Uqq75rxFPkM0w== 2336 | 2337 | strip-json-comments@~2.0.1: 2338 | version "2.0.1" 2339 | resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" 2340 | integrity sha1-PFMZQukIwml8DsNEhYwobHygpgo= 2341 | 2342 | supports-color@^5.3.0, supports-color@^5.5.0: 2343 | version "5.5.0" 2344 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" 2345 | integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== 2346 | dependencies: 2347 | has-flag "^3.0.0" 2348 | 2349 | supports-color@^7.1.0: 2350 | version "7.1.0" 2351 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.1.0.tgz#68e32591df73e25ad1c4b49108a2ec507962bfd1" 2352 | integrity sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g== 2353 | dependencies: 2354 | has-flag "^4.0.0" 2355 | 2356 | table@^5.2.3: 2357 | version "5.4.6" 2358 | resolved "https://registry.yarnpkg.com/table/-/table-5.4.6.tgz#1292d19500ce3f86053b05f0e8e7e4a3bb21079e" 2359 | integrity sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug== 2360 | dependencies: 2361 | ajv "^6.10.2" 2362 | lodash "^4.17.14" 2363 | slice-ansi "^2.1.0" 2364 | string-width "^3.0.0" 2365 | 2366 | tar@^4: 2367 | version "4.4.13" 2368 | resolved "https://registry.yarnpkg.com/tar/-/tar-4.4.13.tgz#43b364bc52888d555298637b10d60790254ab525" 2369 | integrity sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA== 2370 | dependencies: 2371 | chownr "^1.1.1" 2372 | fs-minipass "^1.2.5" 2373 | minipass "^2.8.6" 2374 | minizlib "^1.2.1" 2375 | mkdirp "^0.5.0" 2376 | safe-buffer "^5.1.2" 2377 | yallist "^3.0.3" 2378 | 2379 | term-size@^2.1.0: 2380 | version "2.2.0" 2381 | resolved "https://registry.yarnpkg.com/term-size/-/term-size-2.2.0.tgz#1f16adedfe9bdc18800e1776821734086fcc6753" 2382 | integrity sha512-a6sumDlzyHVJWb8+YofY4TW112G6p2FCPEAFk+59gIYHv3XHRhm9ltVQ9kli4hNWeQBwSpe8cRN25x0ROunMOw== 2383 | 2384 | text-table@^0.2.0: 2385 | version "0.2.0" 2386 | resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" 2387 | integrity sha1-f17oI66AUgfACvLfSoTsP8+lcLQ= 2388 | 2389 | through@^2.3.6: 2390 | version "2.3.8" 2391 | resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" 2392 | integrity sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU= 2393 | 2394 | tmp@^0.0.33: 2395 | version "0.0.33" 2396 | resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.0.33.tgz#6d34335889768d21b2bcda0aa277ced3b1bfadf9" 2397 | integrity sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw== 2398 | dependencies: 2399 | os-tmpdir "~1.0.2" 2400 | 2401 | to-readable-stream@^1.0.0: 2402 | version "1.0.0" 2403 | resolved "https://registry.yarnpkg.com/to-readable-stream/-/to-readable-stream-1.0.0.tgz#ce0aa0c2f3df6adf852efb404a783e77c0475771" 2404 | integrity sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q== 2405 | 2406 | to-regex-range@^5.0.1: 2407 | version "5.0.1" 2408 | resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" 2409 | integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== 2410 | dependencies: 2411 | is-number "^7.0.0" 2412 | 2413 | toidentifier@1.0.0: 2414 | version "1.0.0" 2415 | resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553" 2416 | integrity sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw== 2417 | 2418 | touch@^3.1.0: 2419 | version "3.1.0" 2420 | resolved "https://registry.yarnpkg.com/touch/-/touch-3.1.0.tgz#fe365f5f75ec9ed4e56825e0bb76d24ab74af83b" 2421 | integrity sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA== 2422 | dependencies: 2423 | nopt "~1.0.10" 2424 | 2425 | ts-node@^8.10.1: 2426 | version "8.10.1" 2427 | resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-8.10.1.tgz#77da0366ff8afbe733596361d2df9a60fc9c9bd3" 2428 | integrity sha512-bdNz1L4ekHiJul6SHtZWs1ujEKERJnHs4HxN7rjTyyVOFf3HaJ6sLqe6aPG62XTzAB/63pKRh5jTSWL0D7bsvw== 2429 | dependencies: 2430 | arg "^4.1.0" 2431 | diff "^4.0.1" 2432 | make-error "^1.1.1" 2433 | source-map-support "^0.5.17" 2434 | yn "3.1.1" 2435 | 2436 | tslib@^1.8.1, tslib@^1.9.0: 2437 | version "1.13.0" 2438 | resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.13.0.tgz#c881e13cc7015894ed914862d276436fa9a47043" 2439 | integrity sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q== 2440 | 2441 | tsutils@^3.17.1: 2442 | version "3.17.1" 2443 | resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.17.1.tgz#ed719917f11ca0dee586272b2ac49e015a2dd759" 2444 | integrity sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g== 2445 | dependencies: 2446 | tslib "^1.8.1" 2447 | 2448 | type-check@^0.4.0, type-check@~0.4.0: 2449 | version "0.4.0" 2450 | resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" 2451 | integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== 2452 | dependencies: 2453 | prelude-ls "^1.2.1" 2454 | 2455 | type-fest@^0.11.0: 2456 | version "0.11.0" 2457 | resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.11.0.tgz#97abf0872310fed88a5c466b25681576145e33f1" 2458 | integrity sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ== 2459 | 2460 | type-fest@^0.8.1: 2461 | version "0.8.1" 2462 | resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" 2463 | integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== 2464 | 2465 | type-is@~1.6.17, type-is@~1.6.18: 2466 | version "1.6.18" 2467 | resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" 2468 | integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== 2469 | dependencies: 2470 | media-typer "0.3.0" 2471 | mime-types "~2.1.24" 2472 | 2473 | typedarray-to-buffer@^3.1.5: 2474 | version "3.1.5" 2475 | resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" 2476 | integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== 2477 | dependencies: 2478 | is-typedarray "^1.0.0" 2479 | 2480 | typescript@^3.9.2: 2481 | version "3.9.2" 2482 | resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.2.tgz#64e9c8e9be6ea583c54607677dd4680a1cf35db9" 2483 | integrity sha512-q2ktq4n/uLuNNShyayit+DTobV2ApPEo/6so68JaD5ojvc/6GClBipedB9zNWYxRSAlZXAe405Rlijzl6qDiSw== 2484 | 2485 | undefsafe@^2.0.2: 2486 | version "2.0.3" 2487 | resolved "https://registry.yarnpkg.com/undefsafe/-/undefsafe-2.0.3.tgz#6b166e7094ad46313b2202da7ecc2cd7cc6e7aae" 2488 | integrity sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A== 2489 | dependencies: 2490 | debug "^2.2.0" 2491 | 2492 | unique-string@^2.0.0: 2493 | version "2.0.0" 2494 | resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-2.0.0.tgz#39c6451f81afb2749de2b233e3f7c5e8843bd89d" 2495 | integrity sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg== 2496 | dependencies: 2497 | crypto-random-string "^2.0.0" 2498 | 2499 | unpipe@1.0.0, unpipe@~1.0.0: 2500 | version "1.0.0" 2501 | resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" 2502 | integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= 2503 | 2504 | update-notifier@^4.0.0: 2505 | version "4.1.0" 2506 | resolved "https://registry.yarnpkg.com/update-notifier/-/update-notifier-4.1.0.tgz#4866b98c3bc5b5473c020b1250583628f9a328f3" 2507 | integrity sha512-w3doE1qtI0/ZmgeoDoARmI5fjDoT93IfKgEGqm26dGUOh8oNpaSTsGNdYRN/SjOuo10jcJGwkEL3mroKzktkew== 2508 | dependencies: 2509 | boxen "^4.2.0" 2510 | chalk "^3.0.0" 2511 | configstore "^5.0.1" 2512 | has-yarn "^2.1.0" 2513 | import-lazy "^2.1.0" 2514 | is-ci "^2.0.0" 2515 | is-installed-globally "^0.3.1" 2516 | is-npm "^4.0.0" 2517 | is-yarn-global "^0.3.0" 2518 | latest-version "^5.0.0" 2519 | pupa "^2.0.1" 2520 | semver-diff "^3.1.1" 2521 | xdg-basedir "^4.0.0" 2522 | 2523 | uri-js@^4.2.2: 2524 | version "4.2.2" 2525 | resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.2.2.tgz#94c540e1ff772956e2299507c010aea6c8838eb0" 2526 | integrity sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ== 2527 | dependencies: 2528 | punycode "^2.1.0" 2529 | 2530 | url-parse-lax@^3.0.0: 2531 | version "3.0.0" 2532 | resolved "https://registry.yarnpkg.com/url-parse-lax/-/url-parse-lax-3.0.0.tgz#16b5cafc07dbe3676c1b1999177823d6503acb0c" 2533 | integrity sha1-FrXK/Afb42dsGxmZF3gj1lA6yww= 2534 | dependencies: 2535 | prepend-http "^2.0.0" 2536 | 2537 | url@0.10.3: 2538 | version "0.10.3" 2539 | resolved "https://registry.yarnpkg.com/url/-/url-0.10.3.tgz#021e4d9c7705f21bbf37d03ceb58767402774c64" 2540 | integrity sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ= 2541 | dependencies: 2542 | punycode "1.3.2" 2543 | querystring "0.2.0" 2544 | 2545 | util-deprecate@~1.0.1: 2546 | version "1.0.2" 2547 | resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" 2548 | integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= 2549 | 2550 | utils-merge@1.0.1: 2551 | version "1.0.1" 2552 | resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" 2553 | integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= 2554 | 2555 | uuid@3.3.2: 2556 | version "3.3.2" 2557 | resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.3.2.tgz#1b4af4955eb3077c501c23872fc6513811587131" 2558 | integrity sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA== 2559 | 2560 | v8-compile-cache@^2.0.3: 2561 | version "2.1.0" 2562 | resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz#e14de37b31a6d194f5690d67efc4e7f6fc6ab30e" 2563 | integrity sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g== 2564 | 2565 | vary@~1.1.2: 2566 | version "1.1.2" 2567 | resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" 2568 | integrity sha1-IpnwLG3tMNSllhsLn3RSShj2NPw= 2569 | 2570 | which-pm-runs@^1.0.0: 2571 | version "1.0.0" 2572 | resolved "https://registry.yarnpkg.com/which-pm-runs/-/which-pm-runs-1.0.0.tgz#670b3afbc552e0b55df6b7780ca74615f23ad1cb" 2573 | integrity sha1-Zws6+8VS4LVd9rd4DKdGFfI60cs= 2574 | 2575 | which@^2.0.1: 2576 | version "2.0.2" 2577 | resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" 2578 | integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== 2579 | dependencies: 2580 | isexe "^2.0.0" 2581 | 2582 | wide-align@^1.1.0: 2583 | version "1.1.3" 2584 | resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.3.tgz#ae074e6bdc0c14a431e804e624549c633b000457" 2585 | integrity sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA== 2586 | dependencies: 2587 | string-width "^1.0.2 || 2" 2588 | 2589 | widest-line@^3.1.0: 2590 | version "3.1.0" 2591 | resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-3.1.0.tgz#8292333bbf66cb45ff0de1603b136b7ae1496eca" 2592 | integrity sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg== 2593 | dependencies: 2594 | string-width "^4.0.0" 2595 | 2596 | word-wrap@^1.2.3: 2597 | version "1.2.3" 2598 | resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" 2599 | integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== 2600 | 2601 | wrappy@1: 2602 | version "1.0.2" 2603 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 2604 | integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= 2605 | 2606 | write-file-atomic@^3.0.0: 2607 | version "3.0.3" 2608 | resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" 2609 | integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== 2610 | dependencies: 2611 | imurmurhash "^0.1.4" 2612 | is-typedarray "^1.0.0" 2613 | signal-exit "^3.0.2" 2614 | typedarray-to-buffer "^3.1.5" 2615 | 2616 | write@1.0.3: 2617 | version "1.0.3" 2618 | resolved "https://registry.yarnpkg.com/write/-/write-1.0.3.tgz#0800e14523b923a387e415123c865616aae0f5c3" 2619 | integrity sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig== 2620 | dependencies: 2621 | mkdirp "^0.5.1" 2622 | 2623 | xdg-basedir@^4.0.0: 2624 | version "4.0.0" 2625 | resolved "https://registry.yarnpkg.com/xdg-basedir/-/xdg-basedir-4.0.0.tgz#4bc8d9984403696225ef83a1573cbbcb4e79db13" 2626 | integrity sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q== 2627 | 2628 | xml2js@0.4.19: 2629 | version "0.4.19" 2630 | resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.4.19.tgz#686c20f213209e94abf0d1bcf1efaa291c7827a7" 2631 | integrity sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q== 2632 | dependencies: 2633 | sax ">=0.6.0" 2634 | xmlbuilder "~9.0.1" 2635 | 2636 | xmlbuilder@~9.0.1: 2637 | version "9.0.7" 2638 | resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-9.0.7.tgz#132ee63d2ec5565c557e20f4c22df9aca686b10d" 2639 | integrity sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0= 2640 | 2641 | yallist@^3.0.0, yallist@^3.0.3: 2642 | version "3.1.1" 2643 | resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" 2644 | integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== 2645 | 2646 | yaml@^1.7.2: 2647 | version "1.10.0" 2648 | resolved "https://registry.yarnpkg.com/yaml/-/yaml-1.10.0.tgz#3b593add944876077d4d683fee01081bd9fff31e" 2649 | integrity sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg== 2650 | 2651 | yn@3.1.1: 2652 | version "3.1.1" 2653 | resolved "https://registry.yarnpkg.com/yn/-/yn-3.1.1.tgz#1e87401a09d767c1d5eab26a6e4c185182d2eb50" 2654 | integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== 2655 | --------------------------------------------------------------------------------