├── .env ├── .gitignore ├── .sequelizerc ├── README.md ├── config └── sequelize-cli.js ├── package-lock.json ├── package.json ├── src ├── controllers │ ├── customers-controller.ts │ └── restaurants-controller.ts ├── database │ ├── connect.ts │ ├── index.ts │ ├── migrations │ │ ├── 20220601233650-create-customers-table.js │ │ ├── 20220601233657-create-restaurants-table.js │ │ └── 20220601233703-create-reviews-table.js │ ├── models │ │ ├── customer.ts │ │ ├── restaurant.ts │ │ └── review.ts │ └── seeders │ │ └── 20220602004742-seed-customers-table.js ├── routes.ts ├── server.ts └── services │ ├── customer-service.ts │ ├── restaurant-service.ts │ └── review-service.ts └── tsconfig.json /.env: -------------------------------------------------------------------------------- 1 | DATABASE_URL=postgres://restaurant_api:restaurant_api@localhost:5432/restaurant_api_development -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ -------------------------------------------------------------------------------- /.sequelizerc: -------------------------------------------------------------------------------- 1 | const path = require("path"); 2 | 3 | module.exports = { 4 | config: path.join('config', 'sequelize-cli.js'), 5 | 'migrations-path': path.join('src', 'database', 'migrations'), 6 | 'seeders-path': path.join('src', 'database', 'seeders') 7 | } -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ![imghorizontallogoobc](https://user-images.githubusercontent.com/29529757/176974783-c26e18fc-4712-415c-a281-2fc90169817f.png) 2 | 3 | # API Rest para avaliação de restaurantes 4 | 5 | ## 📖 Descrição 6 | 7 | Esse é o projeto de uma API Rest para avaliação de restaurantes. Ela armazena o cadastro de clientes e restaurantes, em seguida os clientes poderão avaliá-los. 8 | Essa API foi desenvolvida como desafio proposto para a primeira turma do OneBitCode Black. 9 | 10 |
11 | 12 | ## 🛠️ Funcionalidades 13 | 14 | - Armazenar os dados do restaurante 15 | - Armazenar os dados dos clientes 16 | - Os clientes podem avaliar os restaurantes com de 1 a 5 estrelas (⭐⭐⭐⭐⭐) 17 | - Clientes não devem ser capazes de avaliar o mesmo restaurante mais de uma vez 18 | - Obter todas as avaliações que um cliente já fez e uma média dessas avaliações 19 | - Obter todas as avaliações de um restaurante e uma média de estrelas 20 | - Obter os 5 restaurantes mais bem avaliados 21 |
22 | 23 | ## 📡 Tecnologias utilizadas 24 |
25 | NodeJs 26 | Typescript 27 | Sequelize 28 | Express 29 | Postgresql 30 | 31 |
32 |

33 | 34 | ## ⏳ Inicialização 35 | 36 | Esse projeto foi desenvolvido em ambiente Linux, utilizando o Ubuntu 22 e as tecnologias citadas anteriormente. Caso você utilize outro sistema operacional, a configuração inicial do projeto pode ser um pouco diferente, por isso sugerimos que você acesse os links indicados abaixo: 37 | 38 | A preparação do ambiente consiste em instalar as tecnologias citadas anteriormente de acordo com seu sistema operacional. 39 | 40 | Para instalar o Node.js, acesse: https://nodejs.org/pt-br/download/package-manager/ 41 | 42 | O Typescript também precisa ser configurado, utilize essa página como referência: https://www.typescriptlang.org/download 43 | 44 | O sequelize deve ser configurado conforme orientações da documentação oficial: https://sequelize.org/docs/v6/getting-started/ 45 | Para utilizar o express, ele também deve ser instalado: https://expressjs.com/pt-br/starter/installing.html 46 | 47 |
48 | 49 | ## 🔮 Implementações futuras 50 | 1. Implementar possibilidade de realizar entregas, incluindo no pedido a informação se ele será entregue ou não. 51 | 52 | 2. Implementar a possibilidade de o cliente avaliar os entregadores. 53 | 54 | 3. Implementar autenticação para impedir que os clientes façam as alterações em nome de outros clientes. 55 | 56 |
57 | 58 | ## 🤵🤵‍♀️ Colaboradores 59 | 60 | Os colaboradores desse projeto são os Instrutores da OneBitCode: **Isaac Pontes** (Que propos o desafio e é Responsável pelo desenvolvimento dessa API), **Juliana Conde** (Que contribuiu após o desenvolvimento do projeto com o arquivo Readme) e **Lucas Queiroga** (Que também trabalha em melhorias para o projeto). Além de todos os **alunos do OneBitCode Black** ❤️ 61 | 62 |
63 | 64 | ## 🔎 Status do Projeto 65 | 66 | ![Badge em Desenvolvimento](https://img.shields.io/badge/Status-Em%20Desenvolvimento-green) 67 | 68 |
69 | 70 | ## 📑 Referências 71 | 72 | Visite o site da OneBitCode para conhecer os cursos e projetos 73 | https://onebitcode.com/lp/ 74 | 75 | Siga nossa página no instagram: @onebitcode 76 | 77 | Se inscreva no nosso canal do YouTube: https://www.youtube.com/c/OneBitCode 78 | 79 | Conheça o OneBitCode Black: https://chat.whatsapp.com/LOLzh57CDc81UOguDP0OUN 80 | 81 | 82 | 83 | -------------------------------------------------------------------------------- /config/sequelize-cli.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config() 2 | 3 | module.exports = { 4 | dialect: 'postgres', 5 | url: process.env.DATABASE_URL 6 | } -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "restaurant-api", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "restaurant-api", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "dotenv": "^16.0.1", 13 | "express": "^4.18.1", 14 | "pg": "^8.7.3", 15 | "sequelize": "^6.20.1" 16 | }, 17 | "devDependencies": { 18 | "@types/express": "^4.17.13", 19 | "@types/node": "^17.0.38", 20 | "sequelize-cli": "^6.4.1", 21 | "ts-node-dev": "^2.0.0", 22 | "typescript": "^4.7.2" 23 | } 24 | }, 25 | "node_modules/@cspotcode/source-map-support": { 26 | "version": "0.8.1", 27 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 28 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 29 | "dev": true, 30 | "dependencies": { 31 | "@jridgewell/trace-mapping": "0.3.9" 32 | }, 33 | "engines": { 34 | "node": ">=12" 35 | } 36 | }, 37 | "node_modules/@jridgewell/resolve-uri": { 38 | "version": "3.0.7", 39 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.0.7.tgz", 40 | "integrity": "sha512-8cXDaBBHOr2pQ7j77Y6Vp5VDT2sIqWyWQ56TjEq4ih/a4iST3dItRe8Q9fp0rrIl9DoKhWQtUQz/YpOxLkXbNA==", 41 | "dev": true, 42 | "engines": { 43 | "node": ">=6.0.0" 44 | } 45 | }, 46 | "node_modules/@jridgewell/sourcemap-codec": { 47 | "version": "1.4.13", 48 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.13.tgz", 49 | "integrity": "sha512-GryiOJmNcWbovBxTfZSF71V/mXbgcV3MewDe3kIMCLyIh5e7SKAeUZs+rMnJ8jkMolZ/4/VsdBmMrw3l+VdZ3w==", 50 | "dev": true 51 | }, 52 | "node_modules/@jridgewell/trace-mapping": { 53 | "version": "0.3.9", 54 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 55 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 56 | "dev": true, 57 | "dependencies": { 58 | "@jridgewell/resolve-uri": "^3.0.3", 59 | "@jridgewell/sourcemap-codec": "^1.4.10" 60 | } 61 | }, 62 | "node_modules/@tsconfig/node10": { 63 | "version": "1.0.8", 64 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.8.tgz", 65 | "integrity": "sha512-6XFfSQmMgq0CFLY1MslA/CPUfhIL919M1rMsa5lP2P097N2Wd1sSX0tx1u4olM16fLNhtHZpRhedZJphNJqmZg==", 66 | "dev": true 67 | }, 68 | "node_modules/@tsconfig/node12": { 69 | "version": "1.0.9", 70 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.9.tgz", 71 | "integrity": "sha512-/yBMcem+fbvhSREH+s14YJi18sp7J9jpuhYByADT2rypfajMZZN4WQ6zBGgBKp53NKmqI36wFYDb3yaMPurITw==", 72 | "dev": true 73 | }, 74 | "node_modules/@tsconfig/node14": { 75 | "version": "1.0.1", 76 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.1.tgz", 77 | "integrity": "sha512-509r2+yARFfHHE7T6Puu2jjkoycftovhXRqW328PDXTVGKihlb1P8Z9mMZH04ebyajfRY7dedfGynlrFHJUQCg==", 78 | "dev": true 79 | }, 80 | "node_modules/@tsconfig/node16": { 81 | "version": "1.0.2", 82 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.2.tgz", 83 | "integrity": "sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA==", 84 | "dev": true 85 | }, 86 | "node_modules/@types/body-parser": { 87 | "version": "1.19.2", 88 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 89 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 90 | "dev": true, 91 | "dependencies": { 92 | "@types/connect": "*", 93 | "@types/node": "*" 94 | } 95 | }, 96 | "node_modules/@types/connect": { 97 | "version": "3.4.35", 98 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 99 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 100 | "dev": true, 101 | "dependencies": { 102 | "@types/node": "*" 103 | } 104 | }, 105 | "node_modules/@types/debug": { 106 | "version": "4.1.7", 107 | "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.7.tgz", 108 | "integrity": "sha512-9AonUzyTjXXhEOa0DnqpzZi6VHlqKMswga9EXjpXnnqxwLtdvPPtlO8evrI5D9S6asFRCQ6v+wpiUKbw+vKqyg==", 109 | "dependencies": { 110 | "@types/ms": "*" 111 | } 112 | }, 113 | "node_modules/@types/express": { 114 | "version": "4.17.13", 115 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 116 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 117 | "dev": true, 118 | "dependencies": { 119 | "@types/body-parser": "*", 120 | "@types/express-serve-static-core": "^4.17.18", 121 | "@types/qs": "*", 122 | "@types/serve-static": "*" 123 | } 124 | }, 125 | "node_modules/@types/express-serve-static-core": { 126 | "version": "4.17.28", 127 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.28.tgz", 128 | "integrity": "sha512-P1BJAEAW3E2DJUlkgq4tOL3RyMunoWXqbSCygWo5ZIWTjUgN1YnaXWW4VWl/oc8vs/XoYibEGBKP0uZyF4AHig==", 129 | "dev": true, 130 | "dependencies": { 131 | "@types/node": "*", 132 | "@types/qs": "*", 133 | "@types/range-parser": "*" 134 | } 135 | }, 136 | "node_modules/@types/mime": { 137 | "version": "1.3.2", 138 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 139 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 140 | "dev": true 141 | }, 142 | "node_modules/@types/ms": { 143 | "version": "0.7.31", 144 | "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", 145 | "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==" 146 | }, 147 | "node_modules/@types/node": { 148 | "version": "17.0.38", 149 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.38.tgz", 150 | "integrity": "sha512-5jY9RhV7c0Z4Jy09G+NIDTsCZ5G0L5n+Z+p+Y7t5VJHM30bgwzSjVtlcBxqAj+6L/swIlvtOSzr8rBk/aNyV2g==" 151 | }, 152 | "node_modules/@types/qs": { 153 | "version": "6.9.7", 154 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 155 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 156 | "dev": true 157 | }, 158 | "node_modules/@types/range-parser": { 159 | "version": "1.2.4", 160 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 161 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 162 | "dev": true 163 | }, 164 | "node_modules/@types/serve-static": { 165 | "version": "1.13.10", 166 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 167 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 168 | "dev": true, 169 | "dependencies": { 170 | "@types/mime": "^1", 171 | "@types/node": "*" 172 | } 173 | }, 174 | "node_modules/@types/strip-bom": { 175 | "version": "3.0.0", 176 | "resolved": "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz", 177 | "integrity": "sha512-xevGOReSYGM7g/kUBZzPqCrR/KYAo+F0yiPc85WFTJa0MSLtyFTVTU6cJu/aV4mid7IffDIWqo69THF2o4JiEQ==", 178 | "dev": true 179 | }, 180 | "node_modules/@types/strip-json-comments": { 181 | "version": "0.0.30", 182 | "resolved": "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz", 183 | "integrity": "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==", 184 | "dev": true 185 | }, 186 | "node_modules/@types/validator": { 187 | "version": "13.7.2", 188 | "resolved": "https://registry.npmjs.org/@types/validator/-/validator-13.7.2.tgz", 189 | "integrity": "sha512-KFcchQ3h0OPQgFirBRPZr5F/sVjxZsOrQHedj3zi8AH3Zv/hOLx2OLR4hxR5HcfoU+33n69ZuOfzthKVdMoTiw==" 190 | }, 191 | "node_modules/abbrev": { 192 | "version": "1.1.1", 193 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 194 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 195 | "dev": true 196 | }, 197 | "node_modules/accepts": { 198 | "version": "1.3.8", 199 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 200 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 201 | "dependencies": { 202 | "mime-types": "~2.1.34", 203 | "negotiator": "0.6.3" 204 | }, 205 | "engines": { 206 | "node": ">= 0.6" 207 | } 208 | }, 209 | "node_modules/acorn": { 210 | "version": "8.7.1", 211 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz", 212 | "integrity": "sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A==", 213 | "dev": true, 214 | "bin": { 215 | "acorn": "bin/acorn" 216 | }, 217 | "engines": { 218 | "node": ">=0.4.0" 219 | } 220 | }, 221 | "node_modules/acorn-walk": { 222 | "version": "8.2.0", 223 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 224 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 225 | "dev": true, 226 | "engines": { 227 | "node": ">=0.4.0" 228 | } 229 | }, 230 | "node_modules/ansi-regex": { 231 | "version": "5.0.1", 232 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 233 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 234 | "dev": true, 235 | "engines": { 236 | "node": ">=8" 237 | } 238 | }, 239 | "node_modules/ansi-styles": { 240 | "version": "4.3.0", 241 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 242 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 243 | "dev": true, 244 | "dependencies": { 245 | "color-convert": "^2.0.1" 246 | }, 247 | "engines": { 248 | "node": ">=8" 249 | }, 250 | "funding": { 251 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 252 | } 253 | }, 254 | "node_modules/anymatch": { 255 | "version": "3.1.2", 256 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 257 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 258 | "dev": true, 259 | "dependencies": { 260 | "normalize-path": "^3.0.0", 261 | "picomatch": "^2.0.4" 262 | }, 263 | "engines": { 264 | "node": ">= 8" 265 | } 266 | }, 267 | "node_modules/arg": { 268 | "version": "4.1.3", 269 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 270 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 271 | "dev": true 272 | }, 273 | "node_modules/array-flatten": { 274 | "version": "1.1.1", 275 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 276 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 277 | }, 278 | "node_modules/at-least-node": { 279 | "version": "1.0.0", 280 | "resolved": "https://registry.npmjs.org/at-least-node/-/at-least-node-1.0.0.tgz", 281 | "integrity": "sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg==", 282 | "dev": true, 283 | "engines": { 284 | "node": ">= 4.0.0" 285 | } 286 | }, 287 | "node_modules/balanced-match": { 288 | "version": "1.0.2", 289 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 290 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 291 | "dev": true 292 | }, 293 | "node_modules/binary-extensions": { 294 | "version": "2.2.0", 295 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 296 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 297 | "dev": true, 298 | "engines": { 299 | "node": ">=8" 300 | } 301 | }, 302 | "node_modules/bluebird": { 303 | "version": "3.7.2", 304 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 305 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", 306 | "dev": true 307 | }, 308 | "node_modules/body-parser": { 309 | "version": "1.20.0", 310 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz", 311 | "integrity": "sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg==", 312 | "dependencies": { 313 | "bytes": "3.1.2", 314 | "content-type": "~1.0.4", 315 | "debug": "2.6.9", 316 | "depd": "2.0.0", 317 | "destroy": "1.2.0", 318 | "http-errors": "2.0.0", 319 | "iconv-lite": "0.4.24", 320 | "on-finished": "2.4.1", 321 | "qs": "6.10.3", 322 | "raw-body": "2.5.1", 323 | "type-is": "~1.6.18", 324 | "unpipe": "1.0.0" 325 | }, 326 | "engines": { 327 | "node": ">= 0.8", 328 | "npm": "1.2.8000 || >= 1.4.16" 329 | } 330 | }, 331 | "node_modules/brace-expansion": { 332 | "version": "1.1.11", 333 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 334 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 335 | "dev": true, 336 | "dependencies": { 337 | "balanced-match": "^1.0.0", 338 | "concat-map": "0.0.1" 339 | } 340 | }, 341 | "node_modules/braces": { 342 | "version": "3.0.2", 343 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 344 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 345 | "dev": true, 346 | "dependencies": { 347 | "fill-range": "^7.0.1" 348 | }, 349 | "engines": { 350 | "node": ">=8" 351 | } 352 | }, 353 | "node_modules/buffer-from": { 354 | "version": "1.1.2", 355 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 356 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 357 | "dev": true 358 | }, 359 | "node_modules/buffer-writer": { 360 | "version": "2.0.0", 361 | "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz", 362 | "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw==", 363 | "engines": { 364 | "node": ">=4" 365 | } 366 | }, 367 | "node_modules/bytes": { 368 | "version": "3.1.2", 369 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 370 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 371 | "engines": { 372 | "node": ">= 0.8" 373 | } 374 | }, 375 | "node_modules/call-bind": { 376 | "version": "1.0.2", 377 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 378 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 379 | "dependencies": { 380 | "function-bind": "^1.1.1", 381 | "get-intrinsic": "^1.0.2" 382 | }, 383 | "funding": { 384 | "url": "https://github.com/sponsors/ljharb" 385 | } 386 | }, 387 | "node_modules/chokidar": { 388 | "version": "3.5.3", 389 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 390 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 391 | "dev": true, 392 | "funding": [ 393 | { 394 | "type": "individual", 395 | "url": "https://paulmillr.com/funding/" 396 | } 397 | ], 398 | "dependencies": { 399 | "anymatch": "~3.1.2", 400 | "braces": "~3.0.2", 401 | "glob-parent": "~5.1.2", 402 | "is-binary-path": "~2.1.0", 403 | "is-glob": "~4.0.1", 404 | "normalize-path": "~3.0.0", 405 | "readdirp": "~3.6.0" 406 | }, 407 | "engines": { 408 | "node": ">= 8.10.0" 409 | }, 410 | "optionalDependencies": { 411 | "fsevents": "~2.3.2" 412 | } 413 | }, 414 | "node_modules/cli-color": { 415 | "version": "2.0.2", 416 | "resolved": "https://registry.npmjs.org/cli-color/-/cli-color-2.0.2.tgz", 417 | "integrity": "sha512-g4JYjrTW9MGtCziFNjkqp3IMpGhnJyeB0lOtRPjQkYhXzKYr6tYnXKyEVnMzITxhpbahsEW9KsxOYIDKwcsIBw==", 418 | "dev": true, 419 | "dependencies": { 420 | "d": "^1.0.1", 421 | "es5-ext": "^0.10.59", 422 | "es6-iterator": "^2.0.3", 423 | "memoizee": "^0.4.15", 424 | "timers-ext": "^0.1.7" 425 | }, 426 | "engines": { 427 | "node": ">=0.10" 428 | } 429 | }, 430 | "node_modules/cliui": { 431 | "version": "7.0.4", 432 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 433 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 434 | "dev": true, 435 | "dependencies": { 436 | "string-width": "^4.2.0", 437 | "strip-ansi": "^6.0.0", 438 | "wrap-ansi": "^7.0.0" 439 | } 440 | }, 441 | "node_modules/color-convert": { 442 | "version": "2.0.1", 443 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 444 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 445 | "dev": true, 446 | "dependencies": { 447 | "color-name": "~1.1.4" 448 | }, 449 | "engines": { 450 | "node": ">=7.0.0" 451 | } 452 | }, 453 | "node_modules/color-name": { 454 | "version": "1.1.4", 455 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 456 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 457 | "dev": true 458 | }, 459 | "node_modules/commander": { 460 | "version": "2.20.3", 461 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 462 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 463 | "dev": true 464 | }, 465 | "node_modules/concat-map": { 466 | "version": "0.0.1", 467 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 468 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 469 | "dev": true 470 | }, 471 | "node_modules/config-chain": { 472 | "version": "1.1.13", 473 | "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.13.tgz", 474 | "integrity": "sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==", 475 | "dev": true, 476 | "dependencies": { 477 | "ini": "^1.3.4", 478 | "proto-list": "~1.2.1" 479 | } 480 | }, 481 | "node_modules/content-disposition": { 482 | "version": "0.5.4", 483 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 484 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 485 | "dependencies": { 486 | "safe-buffer": "5.2.1" 487 | }, 488 | "engines": { 489 | "node": ">= 0.6" 490 | } 491 | }, 492 | "node_modules/content-type": { 493 | "version": "1.0.4", 494 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 495 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 496 | "engines": { 497 | "node": ">= 0.6" 498 | } 499 | }, 500 | "node_modules/cookie": { 501 | "version": "0.5.0", 502 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 503 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 504 | "engines": { 505 | "node": ">= 0.6" 506 | } 507 | }, 508 | "node_modules/cookie-signature": { 509 | "version": "1.0.6", 510 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 511 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 512 | }, 513 | "node_modules/create-require": { 514 | "version": "1.1.1", 515 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 516 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 517 | "dev": true 518 | }, 519 | "node_modules/d": { 520 | "version": "1.0.1", 521 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", 522 | "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", 523 | "dev": true, 524 | "dependencies": { 525 | "es5-ext": "^0.10.50", 526 | "type": "^1.0.1" 527 | } 528 | }, 529 | "node_modules/debug": { 530 | "version": "2.6.9", 531 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 532 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 533 | "dependencies": { 534 | "ms": "2.0.0" 535 | } 536 | }, 537 | "node_modules/depd": { 538 | "version": "2.0.0", 539 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 540 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 541 | "engines": { 542 | "node": ">= 0.8" 543 | } 544 | }, 545 | "node_modules/destroy": { 546 | "version": "1.2.0", 547 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 548 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 549 | "engines": { 550 | "node": ">= 0.8", 551 | "npm": "1.2.8000 || >= 1.4.16" 552 | } 553 | }, 554 | "node_modules/diff": { 555 | "version": "4.0.2", 556 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 557 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 558 | "dev": true, 559 | "engines": { 560 | "node": ">=0.3.1" 561 | } 562 | }, 563 | "node_modules/dotenv": { 564 | "version": "16.0.1", 565 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz", 566 | "integrity": "sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ==", 567 | "engines": { 568 | "node": ">=12" 569 | } 570 | }, 571 | "node_modules/dottie": { 572 | "version": "2.0.2", 573 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.2.tgz", 574 | "integrity": "sha512-fmrwR04lsniq/uSr8yikThDTrM7epXHBAAjH9TbeH3rEA8tdCO7mRzB9hdmdGyJCxF8KERo9CITcm3kGuoyMhg==" 575 | }, 576 | "node_modules/dynamic-dedupe": { 577 | "version": "0.3.0", 578 | "resolved": "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz", 579 | "integrity": "sha512-ssuANeD+z97meYOqd50e04Ze5qp4bPqo8cCkI4TRjZkzAUgIDTrXV1R8QCdINpiI+hw14+rYazvTRdQrz0/rFQ==", 580 | "dev": true, 581 | "dependencies": { 582 | "xtend": "^4.0.0" 583 | } 584 | }, 585 | "node_modules/editorconfig": { 586 | "version": "0.15.3", 587 | "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", 588 | "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", 589 | "dev": true, 590 | "dependencies": { 591 | "commander": "^2.19.0", 592 | "lru-cache": "^4.1.5", 593 | "semver": "^5.6.0", 594 | "sigmund": "^1.0.1" 595 | }, 596 | "bin": { 597 | "editorconfig": "bin/editorconfig" 598 | } 599 | }, 600 | "node_modules/editorconfig/node_modules/lru-cache": { 601 | "version": "4.1.5", 602 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 603 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 604 | "dev": true, 605 | "dependencies": { 606 | "pseudomap": "^1.0.2", 607 | "yallist": "^2.1.2" 608 | } 609 | }, 610 | "node_modules/editorconfig/node_modules/semver": { 611 | "version": "5.7.1", 612 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 613 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 614 | "dev": true, 615 | "bin": { 616 | "semver": "bin/semver" 617 | } 618 | }, 619 | "node_modules/editorconfig/node_modules/yallist": { 620 | "version": "2.1.2", 621 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 622 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 623 | "dev": true 624 | }, 625 | "node_modules/ee-first": { 626 | "version": "1.1.1", 627 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 628 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 629 | }, 630 | "node_modules/emoji-regex": { 631 | "version": "8.0.0", 632 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 633 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 634 | "dev": true 635 | }, 636 | "node_modules/encodeurl": { 637 | "version": "1.0.2", 638 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 639 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 640 | "engines": { 641 | "node": ">= 0.8" 642 | } 643 | }, 644 | "node_modules/es5-ext": { 645 | "version": "0.10.61", 646 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.61.tgz", 647 | "integrity": "sha512-yFhIqQAzu2Ca2I4SE2Au3rxVfmohU9Y7wqGR+s7+H7krk26NXhIRAZDgqd6xqjCEFUomDEA3/Bo/7fKmIkW1kA==", 648 | "dev": true, 649 | "hasInstallScript": true, 650 | "dependencies": { 651 | "es6-iterator": "^2.0.3", 652 | "es6-symbol": "^3.1.3", 653 | "next-tick": "^1.1.0" 654 | }, 655 | "engines": { 656 | "node": ">=0.10" 657 | } 658 | }, 659 | "node_modules/es6-iterator": { 660 | "version": "2.0.3", 661 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 662 | "integrity": "sha512-zw4SRzoUkd+cl+ZoE15A9o1oQd920Bb0iOJMQkQhl3jNc03YqVjAhG7scf9C5KWRU/R13Orf588uCC6525o02g==", 663 | "dev": true, 664 | "dependencies": { 665 | "d": "1", 666 | "es5-ext": "^0.10.35", 667 | "es6-symbol": "^3.1.1" 668 | } 669 | }, 670 | "node_modules/es6-symbol": { 671 | "version": "3.1.3", 672 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", 673 | "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", 674 | "dev": true, 675 | "dependencies": { 676 | "d": "^1.0.1", 677 | "ext": "^1.1.2" 678 | } 679 | }, 680 | "node_modules/es6-weak-map": { 681 | "version": "2.0.3", 682 | "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.3.tgz", 683 | "integrity": "sha512-p5um32HOTO1kP+w7PRnB+5lQ43Z6muuMuIMffvDN8ZB4GcnjLBV6zGStpbASIMk4DCAvEaamhe2zhyCb/QXXsA==", 684 | "dev": true, 685 | "dependencies": { 686 | "d": "1", 687 | "es5-ext": "^0.10.46", 688 | "es6-iterator": "^2.0.3", 689 | "es6-symbol": "^3.1.1" 690 | } 691 | }, 692 | "node_modules/escalade": { 693 | "version": "3.1.1", 694 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 695 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 696 | "dev": true, 697 | "engines": { 698 | "node": ">=6" 699 | } 700 | }, 701 | "node_modules/escape-html": { 702 | "version": "1.0.3", 703 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 704 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 705 | }, 706 | "node_modules/etag": { 707 | "version": "1.8.1", 708 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 709 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 710 | "engines": { 711 | "node": ">= 0.6" 712 | } 713 | }, 714 | "node_modules/event-emitter": { 715 | "version": "0.3.5", 716 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 717 | "integrity": "sha512-D9rRn9y7kLPnJ+hMq7S/nhvoKwwvVJahBi2BPmx3bvbsEdK3W9ii8cBSGjP+72/LnM4n6fo3+dkCX5FeTQruXA==", 718 | "dev": true, 719 | "dependencies": { 720 | "d": "1", 721 | "es5-ext": "~0.10.14" 722 | } 723 | }, 724 | "node_modules/express": { 725 | "version": "4.18.1", 726 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.1.tgz", 727 | "integrity": "sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q==", 728 | "dependencies": { 729 | "accepts": "~1.3.8", 730 | "array-flatten": "1.1.1", 731 | "body-parser": "1.20.0", 732 | "content-disposition": "0.5.4", 733 | "content-type": "~1.0.4", 734 | "cookie": "0.5.0", 735 | "cookie-signature": "1.0.6", 736 | "debug": "2.6.9", 737 | "depd": "2.0.0", 738 | "encodeurl": "~1.0.2", 739 | "escape-html": "~1.0.3", 740 | "etag": "~1.8.1", 741 | "finalhandler": "1.2.0", 742 | "fresh": "0.5.2", 743 | "http-errors": "2.0.0", 744 | "merge-descriptors": "1.0.1", 745 | "methods": "~1.1.2", 746 | "on-finished": "2.4.1", 747 | "parseurl": "~1.3.3", 748 | "path-to-regexp": "0.1.7", 749 | "proxy-addr": "~2.0.7", 750 | "qs": "6.10.3", 751 | "range-parser": "~1.2.1", 752 | "safe-buffer": "5.2.1", 753 | "send": "0.18.0", 754 | "serve-static": "1.15.0", 755 | "setprototypeof": "1.2.0", 756 | "statuses": "2.0.1", 757 | "type-is": "~1.6.18", 758 | "utils-merge": "1.0.1", 759 | "vary": "~1.1.2" 760 | }, 761 | "engines": { 762 | "node": ">= 0.10.0" 763 | } 764 | }, 765 | "node_modules/ext": { 766 | "version": "1.6.0", 767 | "resolved": "https://registry.npmjs.org/ext/-/ext-1.6.0.tgz", 768 | "integrity": "sha512-sdBImtzkq2HpkdRLtlLWDa6w4DX22ijZLKx8BMPUuKe1c5lbN6xwQDQCxSfxBQnHZ13ls/FH0MQZx/q/gr6FQg==", 769 | "dev": true, 770 | "dependencies": { 771 | "type": "^2.5.0" 772 | } 773 | }, 774 | "node_modules/ext/node_modules/type": { 775 | "version": "2.6.0", 776 | "resolved": "https://registry.npmjs.org/type/-/type-2.6.0.tgz", 777 | "integrity": "sha512-eiDBDOmkih5pMbo9OqsqPRGMljLodLcwd5XD5JbtNB0o89xZAwynY9EdCDsJU7LtcVCClu9DvM7/0Ep1hYX3EQ==", 778 | "dev": true 779 | }, 780 | "node_modules/fill-range": { 781 | "version": "7.0.1", 782 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 783 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 784 | "dev": true, 785 | "dependencies": { 786 | "to-regex-range": "^5.0.1" 787 | }, 788 | "engines": { 789 | "node": ">=8" 790 | } 791 | }, 792 | "node_modules/finalhandler": { 793 | "version": "1.2.0", 794 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 795 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 796 | "dependencies": { 797 | "debug": "2.6.9", 798 | "encodeurl": "~1.0.2", 799 | "escape-html": "~1.0.3", 800 | "on-finished": "2.4.1", 801 | "parseurl": "~1.3.3", 802 | "statuses": "2.0.1", 803 | "unpipe": "~1.0.0" 804 | }, 805 | "engines": { 806 | "node": ">= 0.8" 807 | } 808 | }, 809 | "node_modules/forwarded": { 810 | "version": "0.2.0", 811 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 812 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 813 | "engines": { 814 | "node": ">= 0.6" 815 | } 816 | }, 817 | "node_modules/fresh": { 818 | "version": "0.5.2", 819 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 820 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 821 | "engines": { 822 | "node": ">= 0.6" 823 | } 824 | }, 825 | "node_modules/fs-extra": { 826 | "version": "9.1.0", 827 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", 828 | "integrity": "sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==", 829 | "dev": true, 830 | "dependencies": { 831 | "at-least-node": "^1.0.0", 832 | "graceful-fs": "^4.2.0", 833 | "jsonfile": "^6.0.1", 834 | "universalify": "^2.0.0" 835 | }, 836 | "engines": { 837 | "node": ">=10" 838 | } 839 | }, 840 | "node_modules/fs.realpath": { 841 | "version": "1.0.0", 842 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 843 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 844 | "dev": true 845 | }, 846 | "node_modules/fsevents": { 847 | "version": "2.3.2", 848 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 849 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 850 | "dev": true, 851 | "hasInstallScript": true, 852 | "optional": true, 853 | "os": [ 854 | "darwin" 855 | ], 856 | "engines": { 857 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 858 | } 859 | }, 860 | "node_modules/function-bind": { 861 | "version": "1.1.1", 862 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 863 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 864 | }, 865 | "node_modules/get-caller-file": { 866 | "version": "2.0.5", 867 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 868 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 869 | "dev": true, 870 | "engines": { 871 | "node": "6.* || 8.* || >= 10.*" 872 | } 873 | }, 874 | "node_modules/get-intrinsic": { 875 | "version": "1.1.1", 876 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 877 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 878 | "dependencies": { 879 | "function-bind": "^1.1.1", 880 | "has": "^1.0.3", 881 | "has-symbols": "^1.0.1" 882 | }, 883 | "funding": { 884 | "url": "https://github.com/sponsors/ljharb" 885 | } 886 | }, 887 | "node_modules/glob": { 888 | "version": "7.2.3", 889 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 890 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 891 | "dev": true, 892 | "dependencies": { 893 | "fs.realpath": "^1.0.0", 894 | "inflight": "^1.0.4", 895 | "inherits": "2", 896 | "minimatch": "^3.1.1", 897 | "once": "^1.3.0", 898 | "path-is-absolute": "^1.0.0" 899 | }, 900 | "engines": { 901 | "node": "*" 902 | }, 903 | "funding": { 904 | "url": "https://github.com/sponsors/isaacs" 905 | } 906 | }, 907 | "node_modules/glob-parent": { 908 | "version": "5.1.2", 909 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 910 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 911 | "dev": true, 912 | "dependencies": { 913 | "is-glob": "^4.0.1" 914 | }, 915 | "engines": { 916 | "node": ">= 6" 917 | } 918 | }, 919 | "node_modules/graceful-fs": { 920 | "version": "4.2.10", 921 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", 922 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", 923 | "dev": true 924 | }, 925 | "node_modules/has": { 926 | "version": "1.0.3", 927 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 928 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 929 | "dependencies": { 930 | "function-bind": "^1.1.1" 931 | }, 932 | "engines": { 933 | "node": ">= 0.4.0" 934 | } 935 | }, 936 | "node_modules/has-symbols": { 937 | "version": "1.0.3", 938 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 939 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 940 | "engines": { 941 | "node": ">= 0.4" 942 | }, 943 | "funding": { 944 | "url": "https://github.com/sponsors/ljharb" 945 | } 946 | }, 947 | "node_modules/http-errors": { 948 | "version": "2.0.0", 949 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 950 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 951 | "dependencies": { 952 | "depd": "2.0.0", 953 | "inherits": "2.0.4", 954 | "setprototypeof": "1.2.0", 955 | "statuses": "2.0.1", 956 | "toidentifier": "1.0.1" 957 | }, 958 | "engines": { 959 | "node": ">= 0.8" 960 | } 961 | }, 962 | "node_modules/iconv-lite": { 963 | "version": "0.4.24", 964 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 965 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 966 | "dependencies": { 967 | "safer-buffer": ">= 2.1.2 < 3" 968 | }, 969 | "engines": { 970 | "node": ">=0.10.0" 971 | } 972 | }, 973 | "node_modules/inflection": { 974 | "version": "1.13.2", 975 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.2.tgz", 976 | "integrity": "sha512-cmZlljCRTBFouT8UzMzrGcVEvkv6D/wBdcdKG7J1QH5cXjtU75Dm+P27v9EKu/Y43UYyCJd1WC4zLebRrC8NBw==", 977 | "engines": [ 978 | "node >= 0.4.0" 979 | ] 980 | }, 981 | "node_modules/inflight": { 982 | "version": "1.0.6", 983 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 984 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 985 | "dev": true, 986 | "dependencies": { 987 | "once": "^1.3.0", 988 | "wrappy": "1" 989 | } 990 | }, 991 | "node_modules/inherits": { 992 | "version": "2.0.4", 993 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 994 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 995 | }, 996 | "node_modules/ini": { 997 | "version": "1.3.8", 998 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 999 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", 1000 | "dev": true 1001 | }, 1002 | "node_modules/ipaddr.js": { 1003 | "version": "1.9.1", 1004 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1005 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 1006 | "engines": { 1007 | "node": ">= 0.10" 1008 | } 1009 | }, 1010 | "node_modules/is-binary-path": { 1011 | "version": "2.1.0", 1012 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1013 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1014 | "dev": true, 1015 | "dependencies": { 1016 | "binary-extensions": "^2.0.0" 1017 | }, 1018 | "engines": { 1019 | "node": ">=8" 1020 | } 1021 | }, 1022 | "node_modules/is-core-module": { 1023 | "version": "2.9.0", 1024 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz", 1025 | "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==", 1026 | "dev": true, 1027 | "dependencies": { 1028 | "has": "^1.0.3" 1029 | }, 1030 | "funding": { 1031 | "url": "https://github.com/sponsors/ljharb" 1032 | } 1033 | }, 1034 | "node_modules/is-extglob": { 1035 | "version": "2.1.1", 1036 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1037 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1038 | "dev": true, 1039 | "engines": { 1040 | "node": ">=0.10.0" 1041 | } 1042 | }, 1043 | "node_modules/is-fullwidth-code-point": { 1044 | "version": "3.0.0", 1045 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1046 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1047 | "dev": true, 1048 | "engines": { 1049 | "node": ">=8" 1050 | } 1051 | }, 1052 | "node_modules/is-glob": { 1053 | "version": "4.0.3", 1054 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1055 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1056 | "dev": true, 1057 | "dependencies": { 1058 | "is-extglob": "^2.1.1" 1059 | }, 1060 | "engines": { 1061 | "node": ">=0.10.0" 1062 | } 1063 | }, 1064 | "node_modules/is-number": { 1065 | "version": "7.0.0", 1066 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1067 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1068 | "dev": true, 1069 | "engines": { 1070 | "node": ">=0.12.0" 1071 | } 1072 | }, 1073 | "node_modules/is-promise": { 1074 | "version": "2.2.2", 1075 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.2.2.tgz", 1076 | "integrity": "sha512-+lP4/6lKUBfQjZ2pdxThZvLUAafmZb8OAxFb8XXtiQmS35INgr85hdOGoEs124ez1FCnZJt6jau/T+alh58QFQ==", 1077 | "dev": true 1078 | }, 1079 | "node_modules/js-beautify": { 1080 | "version": "1.14.3", 1081 | "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.3.tgz", 1082 | "integrity": "sha512-f1ra8PHtOEu/70EBnmiUlV8nJePS58y9qKjl4JHfYWlFH6bo7ogZBz//FAZp7jDuXtYnGYKymZPlrg2I/9Zo4g==", 1083 | "dev": true, 1084 | "dependencies": { 1085 | "config-chain": "^1.1.13", 1086 | "editorconfig": "^0.15.3", 1087 | "glob": "^7.1.3", 1088 | "nopt": "^5.0.0" 1089 | }, 1090 | "bin": { 1091 | "css-beautify": "js/bin/css-beautify.js", 1092 | "html-beautify": "js/bin/html-beautify.js", 1093 | "js-beautify": "js/bin/js-beautify.js" 1094 | }, 1095 | "engines": { 1096 | "node": ">=10" 1097 | } 1098 | }, 1099 | "node_modules/jsonfile": { 1100 | "version": "6.1.0", 1101 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", 1102 | "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", 1103 | "dev": true, 1104 | "dependencies": { 1105 | "universalify": "^2.0.0" 1106 | }, 1107 | "optionalDependencies": { 1108 | "graceful-fs": "^4.1.6" 1109 | } 1110 | }, 1111 | "node_modules/lodash": { 1112 | "version": "4.17.21", 1113 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1114 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 1115 | }, 1116 | "node_modules/lru-cache": { 1117 | "version": "6.0.0", 1118 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1119 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1120 | "dependencies": { 1121 | "yallist": "^4.0.0" 1122 | }, 1123 | "engines": { 1124 | "node": ">=10" 1125 | } 1126 | }, 1127 | "node_modules/lru-queue": { 1128 | "version": "0.1.0", 1129 | "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", 1130 | "integrity": "sha512-BpdYkt9EvGl8OfWHDQPISVpcl5xZthb+XPsbELj5AQXxIC8IriDZIQYjBJPEm5rS420sjZ0TLEzRcq5KdBhYrQ==", 1131 | "dev": true, 1132 | "dependencies": { 1133 | "es5-ext": "~0.10.2" 1134 | } 1135 | }, 1136 | "node_modules/make-error": { 1137 | "version": "1.3.6", 1138 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1139 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1140 | "dev": true 1141 | }, 1142 | "node_modules/media-typer": { 1143 | "version": "0.3.0", 1144 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1145 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1146 | "engines": { 1147 | "node": ">= 0.6" 1148 | } 1149 | }, 1150 | "node_modules/memoizee": { 1151 | "version": "0.4.15", 1152 | "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.15.tgz", 1153 | "integrity": "sha512-UBWmJpLZd5STPm7PMUlOw/TSy972M+z8gcyQ5veOnSDRREz/0bmpyTfKt3/51DhEBqCZQn1udM/5flcSPYhkdQ==", 1154 | "dev": true, 1155 | "dependencies": { 1156 | "d": "^1.0.1", 1157 | "es5-ext": "^0.10.53", 1158 | "es6-weak-map": "^2.0.3", 1159 | "event-emitter": "^0.3.5", 1160 | "is-promise": "^2.2.2", 1161 | "lru-queue": "^0.1.0", 1162 | "next-tick": "^1.1.0", 1163 | "timers-ext": "^0.1.7" 1164 | } 1165 | }, 1166 | "node_modules/merge-descriptors": { 1167 | "version": "1.0.1", 1168 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1169 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 1170 | }, 1171 | "node_modules/methods": { 1172 | "version": "1.1.2", 1173 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1174 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 1175 | "engines": { 1176 | "node": ">= 0.6" 1177 | } 1178 | }, 1179 | "node_modules/mime": { 1180 | "version": "1.6.0", 1181 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1182 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1183 | "bin": { 1184 | "mime": "cli.js" 1185 | }, 1186 | "engines": { 1187 | "node": ">=4" 1188 | } 1189 | }, 1190 | "node_modules/mime-db": { 1191 | "version": "1.52.0", 1192 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1193 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1194 | "engines": { 1195 | "node": ">= 0.6" 1196 | } 1197 | }, 1198 | "node_modules/mime-types": { 1199 | "version": "2.1.35", 1200 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1201 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1202 | "dependencies": { 1203 | "mime-db": "1.52.0" 1204 | }, 1205 | "engines": { 1206 | "node": ">= 0.6" 1207 | } 1208 | }, 1209 | "node_modules/minimatch": { 1210 | "version": "3.1.2", 1211 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1212 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1213 | "dev": true, 1214 | "dependencies": { 1215 | "brace-expansion": "^1.1.7" 1216 | }, 1217 | "engines": { 1218 | "node": "*" 1219 | } 1220 | }, 1221 | "node_modules/minimist": { 1222 | "version": "1.2.6", 1223 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1224 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1225 | "dev": true 1226 | }, 1227 | "node_modules/mkdirp": { 1228 | "version": "1.0.4", 1229 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1230 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1231 | "dev": true, 1232 | "bin": { 1233 | "mkdirp": "bin/cmd.js" 1234 | }, 1235 | "engines": { 1236 | "node": ">=10" 1237 | } 1238 | }, 1239 | "node_modules/moment": { 1240 | "version": "2.29.3", 1241 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.3.tgz", 1242 | "integrity": "sha512-c6YRvhEo//6T2Jz/vVtYzqBzwvPT95JBQ+smCytzf7c50oMZRsR/a4w88aD34I+/QVSfnoAnSBFPJHItlOMJVw==", 1243 | "engines": { 1244 | "node": "*" 1245 | } 1246 | }, 1247 | "node_modules/moment-timezone": { 1248 | "version": "0.5.34", 1249 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.34.tgz", 1250 | "integrity": "sha512-3zAEHh2hKUs3EXLESx/wsgw6IQdusOT8Bxm3D9UrHPQR7zlMmzwybC8zHEM1tQ4LJwP7fcxrWr8tuBg05fFCbg==", 1251 | "dependencies": { 1252 | "moment": ">= 2.9.0" 1253 | }, 1254 | "engines": { 1255 | "node": "*" 1256 | } 1257 | }, 1258 | "node_modules/ms": { 1259 | "version": "2.0.0", 1260 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1261 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1262 | }, 1263 | "node_modules/negotiator": { 1264 | "version": "0.6.3", 1265 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1266 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1267 | "engines": { 1268 | "node": ">= 0.6" 1269 | } 1270 | }, 1271 | "node_modules/next-tick": { 1272 | "version": "1.1.0", 1273 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.1.0.tgz", 1274 | "integrity": "sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ==", 1275 | "dev": true 1276 | }, 1277 | "node_modules/nopt": { 1278 | "version": "5.0.0", 1279 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 1280 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 1281 | "dev": true, 1282 | "dependencies": { 1283 | "abbrev": "1" 1284 | }, 1285 | "bin": { 1286 | "nopt": "bin/nopt.js" 1287 | }, 1288 | "engines": { 1289 | "node": ">=6" 1290 | } 1291 | }, 1292 | "node_modules/normalize-path": { 1293 | "version": "3.0.0", 1294 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1295 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1296 | "dev": true, 1297 | "engines": { 1298 | "node": ">=0.10.0" 1299 | } 1300 | }, 1301 | "node_modules/object-inspect": { 1302 | "version": "1.12.2", 1303 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", 1304 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", 1305 | "funding": { 1306 | "url": "https://github.com/sponsors/ljharb" 1307 | } 1308 | }, 1309 | "node_modules/on-finished": { 1310 | "version": "2.4.1", 1311 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1312 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1313 | "dependencies": { 1314 | "ee-first": "1.1.1" 1315 | }, 1316 | "engines": { 1317 | "node": ">= 0.8" 1318 | } 1319 | }, 1320 | "node_modules/once": { 1321 | "version": "1.4.0", 1322 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1323 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1324 | "dev": true, 1325 | "dependencies": { 1326 | "wrappy": "1" 1327 | } 1328 | }, 1329 | "node_modules/packet-reader": { 1330 | "version": "1.0.0", 1331 | "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz", 1332 | "integrity": "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ==" 1333 | }, 1334 | "node_modules/parseurl": { 1335 | "version": "1.3.3", 1336 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1337 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1338 | "engines": { 1339 | "node": ">= 0.8" 1340 | } 1341 | }, 1342 | "node_modules/path-is-absolute": { 1343 | "version": "1.0.1", 1344 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1345 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1346 | "dev": true, 1347 | "engines": { 1348 | "node": ">=0.10.0" 1349 | } 1350 | }, 1351 | "node_modules/path-parse": { 1352 | "version": "1.0.7", 1353 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1354 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1355 | "dev": true 1356 | }, 1357 | "node_modules/path-to-regexp": { 1358 | "version": "0.1.7", 1359 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1360 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 1361 | }, 1362 | "node_modules/pg": { 1363 | "version": "8.7.3", 1364 | "resolved": "https://registry.npmjs.org/pg/-/pg-8.7.3.tgz", 1365 | "integrity": "sha512-HPmH4GH4H3AOprDJOazoIcpI49XFsHCe8xlrjHkWiapdbHK+HLtbm/GQzXYAZwmPju/kzKhjaSfMACG+8cgJcw==", 1366 | "dependencies": { 1367 | "buffer-writer": "2.0.0", 1368 | "packet-reader": "1.0.0", 1369 | "pg-connection-string": "^2.5.0", 1370 | "pg-pool": "^3.5.1", 1371 | "pg-protocol": "^1.5.0", 1372 | "pg-types": "^2.1.0", 1373 | "pgpass": "1.x" 1374 | }, 1375 | "engines": { 1376 | "node": ">= 8.0.0" 1377 | }, 1378 | "peerDependencies": { 1379 | "pg-native": ">=2.0.0" 1380 | }, 1381 | "peerDependenciesMeta": { 1382 | "pg-native": { 1383 | "optional": true 1384 | } 1385 | } 1386 | }, 1387 | "node_modules/pg-connection-string": { 1388 | "version": "2.5.0", 1389 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.5.0.tgz", 1390 | "integrity": "sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ==" 1391 | }, 1392 | "node_modules/pg-int8": { 1393 | "version": "1.0.1", 1394 | "resolved": "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz", 1395 | "integrity": "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw==", 1396 | "engines": { 1397 | "node": ">=4.0.0" 1398 | } 1399 | }, 1400 | "node_modules/pg-pool": { 1401 | "version": "3.5.1", 1402 | "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-3.5.1.tgz", 1403 | "integrity": "sha512-6iCR0wVrro6OOHFsyavV+i6KYL4lVNyYAB9RD18w66xSzN+d8b66HiwuP30Gp1SH5O9T82fckkzsRjlrhD0ioQ==", 1404 | "peerDependencies": { 1405 | "pg": ">=8.0" 1406 | } 1407 | }, 1408 | "node_modules/pg-protocol": { 1409 | "version": "1.5.0", 1410 | "resolved": "https://registry.npmjs.org/pg-protocol/-/pg-protocol-1.5.0.tgz", 1411 | "integrity": "sha512-muRttij7H8TqRNu/DxrAJQITO4Ac7RmX3Klyr/9mJEOBeIpgnF8f9jAfRz5d3XwQZl5qBjF9gLsUtMPJE0vezQ==" 1412 | }, 1413 | "node_modules/pg-types": { 1414 | "version": "2.2.0", 1415 | "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-2.2.0.tgz", 1416 | "integrity": "sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA==", 1417 | "dependencies": { 1418 | "pg-int8": "1.0.1", 1419 | "postgres-array": "~2.0.0", 1420 | "postgres-bytea": "~1.0.0", 1421 | "postgres-date": "~1.0.4", 1422 | "postgres-interval": "^1.1.0" 1423 | }, 1424 | "engines": { 1425 | "node": ">=4" 1426 | } 1427 | }, 1428 | "node_modules/pgpass": { 1429 | "version": "1.0.5", 1430 | "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.5.tgz", 1431 | "integrity": "sha512-FdW9r/jQZhSeohs1Z3sI1yxFQNFvMcnmfuj4WBMUTxOrAyLMaTcE1aAMBiTlbMNaXvBCQuVi0R7hd8udDSP7ug==", 1432 | "dependencies": { 1433 | "split2": "^4.1.0" 1434 | } 1435 | }, 1436 | "node_modules/picomatch": { 1437 | "version": "2.3.1", 1438 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1439 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1440 | "dev": true, 1441 | "engines": { 1442 | "node": ">=8.6" 1443 | }, 1444 | "funding": { 1445 | "url": "https://github.com/sponsors/jonschlinkert" 1446 | } 1447 | }, 1448 | "node_modules/postgres-array": { 1449 | "version": "2.0.0", 1450 | "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz", 1451 | "integrity": "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA==", 1452 | "engines": { 1453 | "node": ">=4" 1454 | } 1455 | }, 1456 | "node_modules/postgres-bytea": { 1457 | "version": "1.0.0", 1458 | "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz", 1459 | "integrity": "sha512-xy3pmLuQqRBZBXDULy7KbaitYqLcmxigw14Q5sj8QBVLqEwXfeybIKVWiqAXTlcvdvb0+xkOtDbfQMOf4lST1w==", 1460 | "engines": { 1461 | "node": ">=0.10.0" 1462 | } 1463 | }, 1464 | "node_modules/postgres-date": { 1465 | "version": "1.0.7", 1466 | "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.7.tgz", 1467 | "integrity": "sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q==", 1468 | "engines": { 1469 | "node": ">=0.10.0" 1470 | } 1471 | }, 1472 | "node_modules/postgres-interval": { 1473 | "version": "1.2.0", 1474 | "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz", 1475 | "integrity": "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==", 1476 | "dependencies": { 1477 | "xtend": "^4.0.0" 1478 | }, 1479 | "engines": { 1480 | "node": ">=0.10.0" 1481 | } 1482 | }, 1483 | "node_modules/proto-list": { 1484 | "version": "1.2.4", 1485 | "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", 1486 | "integrity": "sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk=", 1487 | "dev": true 1488 | }, 1489 | "node_modules/proxy-addr": { 1490 | "version": "2.0.7", 1491 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1492 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1493 | "dependencies": { 1494 | "forwarded": "0.2.0", 1495 | "ipaddr.js": "1.9.1" 1496 | }, 1497 | "engines": { 1498 | "node": ">= 0.10" 1499 | } 1500 | }, 1501 | "node_modules/pseudomap": { 1502 | "version": "1.0.2", 1503 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1504 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 1505 | "dev": true 1506 | }, 1507 | "node_modules/qs": { 1508 | "version": "6.10.3", 1509 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz", 1510 | "integrity": "sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ==", 1511 | "dependencies": { 1512 | "side-channel": "^1.0.4" 1513 | }, 1514 | "engines": { 1515 | "node": ">=0.6" 1516 | }, 1517 | "funding": { 1518 | "url": "https://github.com/sponsors/ljharb" 1519 | } 1520 | }, 1521 | "node_modules/range-parser": { 1522 | "version": "1.2.1", 1523 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1524 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1525 | "engines": { 1526 | "node": ">= 0.6" 1527 | } 1528 | }, 1529 | "node_modules/raw-body": { 1530 | "version": "2.5.1", 1531 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 1532 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 1533 | "dependencies": { 1534 | "bytes": "3.1.2", 1535 | "http-errors": "2.0.0", 1536 | "iconv-lite": "0.4.24", 1537 | "unpipe": "1.0.0" 1538 | }, 1539 | "engines": { 1540 | "node": ">= 0.8" 1541 | } 1542 | }, 1543 | "node_modules/readdirp": { 1544 | "version": "3.6.0", 1545 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1546 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1547 | "dev": true, 1548 | "dependencies": { 1549 | "picomatch": "^2.2.1" 1550 | }, 1551 | "engines": { 1552 | "node": ">=8.10.0" 1553 | } 1554 | }, 1555 | "node_modules/require-directory": { 1556 | "version": "2.1.1", 1557 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1558 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1559 | "dev": true, 1560 | "engines": { 1561 | "node": ">=0.10.0" 1562 | } 1563 | }, 1564 | "node_modules/resolve": { 1565 | "version": "1.22.0", 1566 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 1567 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 1568 | "dev": true, 1569 | "dependencies": { 1570 | "is-core-module": "^2.8.1", 1571 | "path-parse": "^1.0.7", 1572 | "supports-preserve-symlinks-flag": "^1.0.0" 1573 | }, 1574 | "bin": { 1575 | "resolve": "bin/resolve" 1576 | }, 1577 | "funding": { 1578 | "url": "https://github.com/sponsors/ljharb" 1579 | } 1580 | }, 1581 | "node_modules/retry-as-promised": { 1582 | "version": "5.0.0", 1583 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-5.0.0.tgz", 1584 | "integrity": "sha512-6S+5LvtTl2ggBumk04hBo/4Uf6fRJUwIgunGZ7CYEBCeufGFW1Pu6ucUf/UskHeWOIsUcLOGLFXPig5tR5V1nA==" 1585 | }, 1586 | "node_modules/rimraf": { 1587 | "version": "2.7.1", 1588 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1589 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1590 | "dev": true, 1591 | "dependencies": { 1592 | "glob": "^7.1.3" 1593 | }, 1594 | "bin": { 1595 | "rimraf": "bin.js" 1596 | } 1597 | }, 1598 | "node_modules/safe-buffer": { 1599 | "version": "5.2.1", 1600 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1601 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1602 | "funding": [ 1603 | { 1604 | "type": "github", 1605 | "url": "https://github.com/sponsors/feross" 1606 | }, 1607 | { 1608 | "type": "patreon", 1609 | "url": "https://www.patreon.com/feross" 1610 | }, 1611 | { 1612 | "type": "consulting", 1613 | "url": "https://feross.org/support" 1614 | } 1615 | ] 1616 | }, 1617 | "node_modules/safer-buffer": { 1618 | "version": "2.1.2", 1619 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1620 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1621 | }, 1622 | "node_modules/semver": { 1623 | "version": "7.3.7", 1624 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 1625 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 1626 | "dependencies": { 1627 | "lru-cache": "^6.0.0" 1628 | }, 1629 | "bin": { 1630 | "semver": "bin/semver.js" 1631 | }, 1632 | "engines": { 1633 | "node": ">=10" 1634 | } 1635 | }, 1636 | "node_modules/send": { 1637 | "version": "0.18.0", 1638 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1639 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1640 | "dependencies": { 1641 | "debug": "2.6.9", 1642 | "depd": "2.0.0", 1643 | "destroy": "1.2.0", 1644 | "encodeurl": "~1.0.2", 1645 | "escape-html": "~1.0.3", 1646 | "etag": "~1.8.1", 1647 | "fresh": "0.5.2", 1648 | "http-errors": "2.0.0", 1649 | "mime": "1.6.0", 1650 | "ms": "2.1.3", 1651 | "on-finished": "2.4.1", 1652 | "range-parser": "~1.2.1", 1653 | "statuses": "2.0.1" 1654 | }, 1655 | "engines": { 1656 | "node": ">= 0.8.0" 1657 | } 1658 | }, 1659 | "node_modules/send/node_modules/ms": { 1660 | "version": "2.1.3", 1661 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1662 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1663 | }, 1664 | "node_modules/sequelize": { 1665 | "version": "6.20.1", 1666 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.20.1.tgz", 1667 | "integrity": "sha512-1YBMv++Yy1JBFFiac1Xoa+Km5qV6YI1ckdkW0xyD7IpLMtE5JmjgZdZXGfwgRUNjhaKMxdzT+nkvJgeXO0rv/g==", 1668 | "funding": [ 1669 | { 1670 | "type": "opencollective", 1671 | "url": "https://opencollective.com/sequelize" 1672 | } 1673 | ], 1674 | "dependencies": { 1675 | "@types/debug": "^4.1.7", 1676 | "@types/validator": "^13.7.1", 1677 | "debug": "^4.3.3", 1678 | "dottie": "^2.0.2", 1679 | "inflection": "^1.13.2", 1680 | "lodash": "^4.17.21", 1681 | "moment": "^2.29.1", 1682 | "moment-timezone": "^0.5.34", 1683 | "pg-connection-string": "^2.5.0", 1684 | "retry-as-promised": "^5.0.0", 1685 | "semver": "^7.3.5", 1686 | "sequelize-pool": "^7.1.0", 1687 | "toposort-class": "^1.0.1", 1688 | "uuid": "^8.3.2", 1689 | "validator": "^13.7.0", 1690 | "wkx": "^0.5.0" 1691 | }, 1692 | "engines": { 1693 | "node": ">=10.0.0" 1694 | }, 1695 | "peerDependenciesMeta": { 1696 | "ibm_db": { 1697 | "optional": true 1698 | }, 1699 | "mariadb": { 1700 | "optional": true 1701 | }, 1702 | "mysql2": { 1703 | "optional": true 1704 | }, 1705 | "pg": { 1706 | "optional": true 1707 | }, 1708 | "pg-hstore": { 1709 | "optional": true 1710 | }, 1711 | "snowflake-sdk": { 1712 | "optional": true 1713 | }, 1714 | "sqlite3": { 1715 | "optional": true 1716 | }, 1717 | "tedious": { 1718 | "optional": true 1719 | } 1720 | } 1721 | }, 1722 | "node_modules/sequelize-cli": { 1723 | "version": "6.4.1", 1724 | "resolved": "https://registry.npmjs.org/sequelize-cli/-/sequelize-cli-6.4.1.tgz", 1725 | "integrity": "sha512-gIzzFitUGUErq6DYd1JDnsmx7z7XcxzRNe4Py3AqeaxcyjpCAZU2BQnsNPGPMKAaXfMtKi/d9Tu4MtLrehVzIQ==", 1726 | "dev": true, 1727 | "dependencies": { 1728 | "cli-color": "^2.0.1", 1729 | "fs-extra": "^9.1.0", 1730 | "js-beautify": "^1.14.0", 1731 | "lodash": "^4.17.21", 1732 | "resolve": "^1.20.0", 1733 | "umzug": "^2.3.0", 1734 | "yargs": "^16.2.0" 1735 | }, 1736 | "bin": { 1737 | "sequelize": "lib/sequelize", 1738 | "sequelize-cli": "lib/sequelize" 1739 | }, 1740 | "engines": { 1741 | "node": ">=10.0.0" 1742 | } 1743 | }, 1744 | "node_modules/sequelize-pool": { 1745 | "version": "7.1.0", 1746 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-7.1.0.tgz", 1747 | "integrity": "sha512-G9c0qlIWQSK29pR/5U2JF5dDQeqqHRragoyahj/Nx4KOOQ3CPPfzxnfqFPCSB7x5UgjOgnZ61nSxz+fjDpRlJg==", 1748 | "engines": { 1749 | "node": ">= 10.0.0" 1750 | } 1751 | }, 1752 | "node_modules/sequelize/node_modules/debug": { 1753 | "version": "4.3.4", 1754 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1755 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1756 | "dependencies": { 1757 | "ms": "2.1.2" 1758 | }, 1759 | "engines": { 1760 | "node": ">=6.0" 1761 | }, 1762 | "peerDependenciesMeta": { 1763 | "supports-color": { 1764 | "optional": true 1765 | } 1766 | } 1767 | }, 1768 | "node_modules/sequelize/node_modules/ms": { 1769 | "version": "2.1.2", 1770 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1771 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1772 | }, 1773 | "node_modules/serve-static": { 1774 | "version": "1.15.0", 1775 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1776 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1777 | "dependencies": { 1778 | "encodeurl": "~1.0.2", 1779 | "escape-html": "~1.0.3", 1780 | "parseurl": "~1.3.3", 1781 | "send": "0.18.0" 1782 | }, 1783 | "engines": { 1784 | "node": ">= 0.8.0" 1785 | } 1786 | }, 1787 | "node_modules/setprototypeof": { 1788 | "version": "1.2.0", 1789 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1790 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1791 | }, 1792 | "node_modules/side-channel": { 1793 | "version": "1.0.4", 1794 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1795 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1796 | "dependencies": { 1797 | "call-bind": "^1.0.0", 1798 | "get-intrinsic": "^1.0.2", 1799 | "object-inspect": "^1.9.0" 1800 | }, 1801 | "funding": { 1802 | "url": "https://github.com/sponsors/ljharb" 1803 | } 1804 | }, 1805 | "node_modules/sigmund": { 1806 | "version": "1.0.1", 1807 | "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", 1808 | "integrity": "sha1-P/IfGYytIXX587eBhT/ZTQ0ZtZA=", 1809 | "dev": true 1810 | }, 1811 | "node_modules/source-map": { 1812 | "version": "0.6.1", 1813 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1814 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1815 | "dev": true, 1816 | "engines": { 1817 | "node": ">=0.10.0" 1818 | } 1819 | }, 1820 | "node_modules/source-map-support": { 1821 | "version": "0.5.21", 1822 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1823 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1824 | "dev": true, 1825 | "dependencies": { 1826 | "buffer-from": "^1.0.0", 1827 | "source-map": "^0.6.0" 1828 | } 1829 | }, 1830 | "node_modules/split2": { 1831 | "version": "4.1.0", 1832 | "resolved": "https://registry.npmjs.org/split2/-/split2-4.1.0.tgz", 1833 | "integrity": "sha512-VBiJxFkxiXRlUIeyMQi8s4hgvKCSjtknJv/LVYbrgALPwf5zSKmEwV9Lst25AkvMDnvxODugjdl6KZgwKM1WYQ==", 1834 | "engines": { 1835 | "node": ">= 10.x" 1836 | } 1837 | }, 1838 | "node_modules/statuses": { 1839 | "version": "2.0.1", 1840 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1841 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1842 | "engines": { 1843 | "node": ">= 0.8" 1844 | } 1845 | }, 1846 | "node_modules/string-width": { 1847 | "version": "4.2.3", 1848 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1849 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1850 | "dev": true, 1851 | "dependencies": { 1852 | "emoji-regex": "^8.0.0", 1853 | "is-fullwidth-code-point": "^3.0.0", 1854 | "strip-ansi": "^6.0.1" 1855 | }, 1856 | "engines": { 1857 | "node": ">=8" 1858 | } 1859 | }, 1860 | "node_modules/strip-ansi": { 1861 | "version": "6.0.1", 1862 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1863 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1864 | "dev": true, 1865 | "dependencies": { 1866 | "ansi-regex": "^5.0.1" 1867 | }, 1868 | "engines": { 1869 | "node": ">=8" 1870 | } 1871 | }, 1872 | "node_modules/strip-bom": { 1873 | "version": "3.0.0", 1874 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1875 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1876 | "dev": true, 1877 | "engines": { 1878 | "node": ">=4" 1879 | } 1880 | }, 1881 | "node_modules/strip-json-comments": { 1882 | "version": "2.0.1", 1883 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1884 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1885 | "dev": true, 1886 | "engines": { 1887 | "node": ">=0.10.0" 1888 | } 1889 | }, 1890 | "node_modules/supports-preserve-symlinks-flag": { 1891 | "version": "1.0.0", 1892 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1893 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1894 | "dev": true, 1895 | "engines": { 1896 | "node": ">= 0.4" 1897 | }, 1898 | "funding": { 1899 | "url": "https://github.com/sponsors/ljharb" 1900 | } 1901 | }, 1902 | "node_modules/timers-ext": { 1903 | "version": "0.1.7", 1904 | "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.7.tgz", 1905 | "integrity": "sha512-b85NUNzTSdodShTIbky6ZF02e8STtVVfD+fu4aXXShEELpozH+bCpJLYMPZbsABN2wDH7fJpqIoXxJpzbf0NqQ==", 1906 | "dev": true, 1907 | "dependencies": { 1908 | "es5-ext": "~0.10.46", 1909 | "next-tick": "1" 1910 | } 1911 | }, 1912 | "node_modules/to-regex-range": { 1913 | "version": "5.0.1", 1914 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1915 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1916 | "dev": true, 1917 | "dependencies": { 1918 | "is-number": "^7.0.0" 1919 | }, 1920 | "engines": { 1921 | "node": ">=8.0" 1922 | } 1923 | }, 1924 | "node_modules/toidentifier": { 1925 | "version": "1.0.1", 1926 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1927 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1928 | "engines": { 1929 | "node": ">=0.6" 1930 | } 1931 | }, 1932 | "node_modules/toposort-class": { 1933 | "version": "1.0.1", 1934 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 1935 | "integrity": "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg=" 1936 | }, 1937 | "node_modules/tree-kill": { 1938 | "version": "1.2.2", 1939 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", 1940 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", 1941 | "dev": true, 1942 | "bin": { 1943 | "tree-kill": "cli.js" 1944 | } 1945 | }, 1946 | "node_modules/ts-node": { 1947 | "version": "10.8.0", 1948 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.8.0.tgz", 1949 | "integrity": "sha512-/fNd5Qh+zTt8Vt1KbYZjRHCE9sI5i7nqfD/dzBBRDeVXZXS6kToW6R7tTU6Nd4XavFs0mAVCg29Q//ML7WsZYA==", 1950 | "dev": true, 1951 | "dependencies": { 1952 | "@cspotcode/source-map-support": "^0.8.0", 1953 | "@tsconfig/node10": "^1.0.7", 1954 | "@tsconfig/node12": "^1.0.7", 1955 | "@tsconfig/node14": "^1.0.0", 1956 | "@tsconfig/node16": "^1.0.2", 1957 | "acorn": "^8.4.1", 1958 | "acorn-walk": "^8.1.1", 1959 | "arg": "^4.1.0", 1960 | "create-require": "^1.1.0", 1961 | "diff": "^4.0.1", 1962 | "make-error": "^1.1.1", 1963 | "v8-compile-cache-lib": "^3.0.1", 1964 | "yn": "3.1.1" 1965 | }, 1966 | "bin": { 1967 | "ts-node": "dist/bin.js", 1968 | "ts-node-cwd": "dist/bin-cwd.js", 1969 | "ts-node-esm": "dist/bin-esm.js", 1970 | "ts-node-script": "dist/bin-script.js", 1971 | "ts-node-transpile-only": "dist/bin-transpile.js", 1972 | "ts-script": "dist/bin-script-deprecated.js" 1973 | }, 1974 | "peerDependencies": { 1975 | "@swc/core": ">=1.2.50", 1976 | "@swc/wasm": ">=1.2.50", 1977 | "@types/node": "*", 1978 | "typescript": ">=2.7" 1979 | }, 1980 | "peerDependenciesMeta": { 1981 | "@swc/core": { 1982 | "optional": true 1983 | }, 1984 | "@swc/wasm": { 1985 | "optional": true 1986 | } 1987 | } 1988 | }, 1989 | "node_modules/ts-node-dev": { 1990 | "version": "2.0.0", 1991 | "resolved": "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz", 1992 | "integrity": "sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w==", 1993 | "dev": true, 1994 | "dependencies": { 1995 | "chokidar": "^3.5.1", 1996 | "dynamic-dedupe": "^0.3.0", 1997 | "minimist": "^1.2.6", 1998 | "mkdirp": "^1.0.4", 1999 | "resolve": "^1.0.0", 2000 | "rimraf": "^2.6.1", 2001 | "source-map-support": "^0.5.12", 2002 | "tree-kill": "^1.2.2", 2003 | "ts-node": "^10.4.0", 2004 | "tsconfig": "^7.0.0" 2005 | }, 2006 | "bin": { 2007 | "ts-node-dev": "lib/bin.js", 2008 | "tsnd": "lib/bin.js" 2009 | }, 2010 | "engines": { 2011 | "node": ">=0.8.0" 2012 | }, 2013 | "peerDependencies": { 2014 | "node-notifier": "*", 2015 | "typescript": "*" 2016 | }, 2017 | "peerDependenciesMeta": { 2018 | "node-notifier": { 2019 | "optional": true 2020 | } 2021 | } 2022 | }, 2023 | "node_modules/tsconfig": { 2024 | "version": "7.0.0", 2025 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz", 2026 | "integrity": "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==", 2027 | "dev": true, 2028 | "dependencies": { 2029 | "@types/strip-bom": "^3.0.0", 2030 | "@types/strip-json-comments": "0.0.30", 2031 | "strip-bom": "^3.0.0", 2032 | "strip-json-comments": "^2.0.0" 2033 | } 2034 | }, 2035 | "node_modules/type": { 2036 | "version": "1.2.0", 2037 | "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", 2038 | "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==", 2039 | "dev": true 2040 | }, 2041 | "node_modules/type-is": { 2042 | "version": "1.6.18", 2043 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2044 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2045 | "dependencies": { 2046 | "media-typer": "0.3.0", 2047 | "mime-types": "~2.1.24" 2048 | }, 2049 | "engines": { 2050 | "node": ">= 0.6" 2051 | } 2052 | }, 2053 | "node_modules/typescript": { 2054 | "version": "4.7.2", 2055 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.7.2.tgz", 2056 | "integrity": "sha512-Mamb1iX2FDUpcTRzltPxgWMKy3fhg0TN378ylbktPGPK/99KbDtMQ4W1hwgsbPAsG3a0xKa1vmw4VKZQbkvz5A==", 2057 | "dev": true, 2058 | "bin": { 2059 | "tsc": "bin/tsc", 2060 | "tsserver": "bin/tsserver" 2061 | }, 2062 | "engines": { 2063 | "node": ">=4.2.0" 2064 | } 2065 | }, 2066 | "node_modules/umzug": { 2067 | "version": "2.3.0", 2068 | "resolved": "https://registry.npmjs.org/umzug/-/umzug-2.3.0.tgz", 2069 | "integrity": "sha512-Z274K+e8goZK8QJxmbRPhl89HPO1K+ORFtm6rySPhFKfKc5GHhqdzD0SGhSWHkzoXasqJuItdhorSvY7/Cgflw==", 2070 | "dev": true, 2071 | "dependencies": { 2072 | "bluebird": "^3.7.2" 2073 | }, 2074 | "engines": { 2075 | "node": ">=6.0.0" 2076 | } 2077 | }, 2078 | "node_modules/universalify": { 2079 | "version": "2.0.0", 2080 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.0.tgz", 2081 | "integrity": "sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==", 2082 | "dev": true, 2083 | "engines": { 2084 | "node": ">= 10.0.0" 2085 | } 2086 | }, 2087 | "node_modules/unpipe": { 2088 | "version": "1.0.0", 2089 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2090 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 2091 | "engines": { 2092 | "node": ">= 0.8" 2093 | } 2094 | }, 2095 | "node_modules/utils-merge": { 2096 | "version": "1.0.1", 2097 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2098 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 2099 | "engines": { 2100 | "node": ">= 0.4.0" 2101 | } 2102 | }, 2103 | "node_modules/uuid": { 2104 | "version": "8.3.2", 2105 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 2106 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 2107 | "bin": { 2108 | "uuid": "dist/bin/uuid" 2109 | } 2110 | }, 2111 | "node_modules/v8-compile-cache-lib": { 2112 | "version": "3.0.1", 2113 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 2114 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 2115 | "dev": true 2116 | }, 2117 | "node_modules/validator": { 2118 | "version": "13.7.0", 2119 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.7.0.tgz", 2120 | "integrity": "sha512-nYXQLCBkpJ8X6ltALua9dRrZDHVYxjJ1wgskNt1lH9fzGjs3tgojGSCBjmEPwkWS1y29+DrizMTW19Pr9uB2nw==", 2121 | "engines": { 2122 | "node": ">= 0.10" 2123 | } 2124 | }, 2125 | "node_modules/vary": { 2126 | "version": "1.1.2", 2127 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2128 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 2129 | "engines": { 2130 | "node": ">= 0.8" 2131 | } 2132 | }, 2133 | "node_modules/wkx": { 2134 | "version": "0.5.0", 2135 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz", 2136 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==", 2137 | "dependencies": { 2138 | "@types/node": "*" 2139 | } 2140 | }, 2141 | "node_modules/wrap-ansi": { 2142 | "version": "7.0.0", 2143 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2144 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2145 | "dev": true, 2146 | "dependencies": { 2147 | "ansi-styles": "^4.0.0", 2148 | "string-width": "^4.1.0", 2149 | "strip-ansi": "^6.0.0" 2150 | }, 2151 | "engines": { 2152 | "node": ">=10" 2153 | }, 2154 | "funding": { 2155 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2156 | } 2157 | }, 2158 | "node_modules/wrappy": { 2159 | "version": "1.0.2", 2160 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2161 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2162 | "dev": true 2163 | }, 2164 | "node_modules/xtend": { 2165 | "version": "4.0.2", 2166 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2167 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 2168 | "engines": { 2169 | "node": ">=0.4" 2170 | } 2171 | }, 2172 | "node_modules/y18n": { 2173 | "version": "5.0.8", 2174 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2175 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2176 | "dev": true, 2177 | "engines": { 2178 | "node": ">=10" 2179 | } 2180 | }, 2181 | "node_modules/yallist": { 2182 | "version": "4.0.0", 2183 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2184 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 2185 | }, 2186 | "node_modules/yargs": { 2187 | "version": "16.2.0", 2188 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2189 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2190 | "dev": true, 2191 | "dependencies": { 2192 | "cliui": "^7.0.2", 2193 | "escalade": "^3.1.1", 2194 | "get-caller-file": "^2.0.5", 2195 | "require-directory": "^2.1.1", 2196 | "string-width": "^4.2.0", 2197 | "y18n": "^5.0.5", 2198 | "yargs-parser": "^20.2.2" 2199 | }, 2200 | "engines": { 2201 | "node": ">=10" 2202 | } 2203 | }, 2204 | "node_modules/yargs-parser": { 2205 | "version": "20.2.9", 2206 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 2207 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 2208 | "dev": true, 2209 | "engines": { 2210 | "node": ">=10" 2211 | } 2212 | }, 2213 | "node_modules/yn": { 2214 | "version": "3.1.1", 2215 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 2216 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 2217 | "dev": true, 2218 | "engines": { 2219 | "node": ">=6" 2220 | } 2221 | } 2222 | }, 2223 | "dependencies": { 2224 | "@cspotcode/source-map-support": { 2225 | "version": "0.8.1", 2226 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 2227 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 2228 | "dev": true, 2229 | "requires": { 2230 | "@jridgewell/trace-mapping": "0.3.9" 2231 | } 2232 | }, 2233 | "@jridgewell/resolve-uri": { 2234 | "version": "3.0.7", 2235 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.0.7.tgz", 2236 | "integrity": "sha512-8cXDaBBHOr2pQ7j77Y6Vp5VDT2sIqWyWQ56TjEq4ih/a4iST3dItRe8Q9fp0rrIl9DoKhWQtUQz/YpOxLkXbNA==", 2237 | "dev": true 2238 | }, 2239 | "@jridgewell/sourcemap-codec": { 2240 | "version": "1.4.13", 2241 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.13.tgz", 2242 | "integrity": "sha512-GryiOJmNcWbovBxTfZSF71V/mXbgcV3MewDe3kIMCLyIh5e7SKAeUZs+rMnJ8jkMolZ/4/VsdBmMrw3l+VdZ3w==", 2243 | "dev": true 2244 | }, 2245 | "@jridgewell/trace-mapping": { 2246 | "version": "0.3.9", 2247 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 2248 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 2249 | "dev": true, 2250 | "requires": { 2251 | "@jridgewell/resolve-uri": "^3.0.3", 2252 | "@jridgewell/sourcemap-codec": "^1.4.10" 2253 | } 2254 | }, 2255 | "@tsconfig/node10": { 2256 | "version": "1.0.8", 2257 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.8.tgz", 2258 | "integrity": "sha512-6XFfSQmMgq0CFLY1MslA/CPUfhIL919M1rMsa5lP2P097N2Wd1sSX0tx1u4olM16fLNhtHZpRhedZJphNJqmZg==", 2259 | "dev": true 2260 | }, 2261 | "@tsconfig/node12": { 2262 | "version": "1.0.9", 2263 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.9.tgz", 2264 | "integrity": "sha512-/yBMcem+fbvhSREH+s14YJi18sp7J9jpuhYByADT2rypfajMZZN4WQ6zBGgBKp53NKmqI36wFYDb3yaMPurITw==", 2265 | "dev": true 2266 | }, 2267 | "@tsconfig/node14": { 2268 | "version": "1.0.1", 2269 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.1.tgz", 2270 | "integrity": "sha512-509r2+yARFfHHE7T6Puu2jjkoycftovhXRqW328PDXTVGKihlb1P8Z9mMZH04ebyajfRY7dedfGynlrFHJUQCg==", 2271 | "dev": true 2272 | }, 2273 | "@tsconfig/node16": { 2274 | "version": "1.0.2", 2275 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.2.tgz", 2276 | "integrity": "sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA==", 2277 | "dev": true 2278 | }, 2279 | "@types/body-parser": { 2280 | "version": "1.19.2", 2281 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 2282 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 2283 | "dev": true, 2284 | "requires": { 2285 | "@types/connect": "*", 2286 | "@types/node": "*" 2287 | } 2288 | }, 2289 | "@types/connect": { 2290 | "version": "3.4.35", 2291 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 2292 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 2293 | "dev": true, 2294 | "requires": { 2295 | "@types/node": "*" 2296 | } 2297 | }, 2298 | "@types/debug": { 2299 | "version": "4.1.7", 2300 | "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.7.tgz", 2301 | "integrity": "sha512-9AonUzyTjXXhEOa0DnqpzZi6VHlqKMswga9EXjpXnnqxwLtdvPPtlO8evrI5D9S6asFRCQ6v+wpiUKbw+vKqyg==", 2302 | "requires": { 2303 | "@types/ms": "*" 2304 | } 2305 | }, 2306 | "@types/express": { 2307 | "version": "4.17.13", 2308 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 2309 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 2310 | "dev": true, 2311 | "requires": { 2312 | "@types/body-parser": "*", 2313 | "@types/express-serve-static-core": "^4.17.18", 2314 | "@types/qs": "*", 2315 | "@types/serve-static": "*" 2316 | } 2317 | }, 2318 | "@types/express-serve-static-core": { 2319 | "version": "4.17.28", 2320 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.28.tgz", 2321 | "integrity": "sha512-P1BJAEAW3E2DJUlkgq4tOL3RyMunoWXqbSCygWo5ZIWTjUgN1YnaXWW4VWl/oc8vs/XoYibEGBKP0uZyF4AHig==", 2322 | "dev": true, 2323 | "requires": { 2324 | "@types/node": "*", 2325 | "@types/qs": "*", 2326 | "@types/range-parser": "*" 2327 | } 2328 | }, 2329 | "@types/mime": { 2330 | "version": "1.3.2", 2331 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 2332 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 2333 | "dev": true 2334 | }, 2335 | "@types/ms": { 2336 | "version": "0.7.31", 2337 | "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", 2338 | "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==" 2339 | }, 2340 | "@types/node": { 2341 | "version": "17.0.38", 2342 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.38.tgz", 2343 | "integrity": "sha512-5jY9RhV7c0Z4Jy09G+NIDTsCZ5G0L5n+Z+p+Y7t5VJHM30bgwzSjVtlcBxqAj+6L/swIlvtOSzr8rBk/aNyV2g==" 2344 | }, 2345 | "@types/qs": { 2346 | "version": "6.9.7", 2347 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 2348 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 2349 | "dev": true 2350 | }, 2351 | "@types/range-parser": { 2352 | "version": "1.2.4", 2353 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 2354 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 2355 | "dev": true 2356 | }, 2357 | "@types/serve-static": { 2358 | "version": "1.13.10", 2359 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 2360 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 2361 | "dev": true, 2362 | "requires": { 2363 | "@types/mime": "^1", 2364 | "@types/node": "*" 2365 | } 2366 | }, 2367 | "@types/strip-bom": { 2368 | "version": "3.0.0", 2369 | "resolved": "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz", 2370 | "integrity": "sha512-xevGOReSYGM7g/kUBZzPqCrR/KYAo+F0yiPc85WFTJa0MSLtyFTVTU6cJu/aV4mid7IffDIWqo69THF2o4JiEQ==", 2371 | "dev": true 2372 | }, 2373 | "@types/strip-json-comments": { 2374 | "version": "0.0.30", 2375 | "resolved": "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz", 2376 | "integrity": "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==", 2377 | "dev": true 2378 | }, 2379 | "@types/validator": { 2380 | "version": "13.7.2", 2381 | "resolved": "https://registry.npmjs.org/@types/validator/-/validator-13.7.2.tgz", 2382 | "integrity": "sha512-KFcchQ3h0OPQgFirBRPZr5F/sVjxZsOrQHedj3zi8AH3Zv/hOLx2OLR4hxR5HcfoU+33n69ZuOfzthKVdMoTiw==" 2383 | }, 2384 | "abbrev": { 2385 | "version": "1.1.1", 2386 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 2387 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 2388 | "dev": true 2389 | }, 2390 | "accepts": { 2391 | "version": "1.3.8", 2392 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 2393 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 2394 | "requires": { 2395 | "mime-types": "~2.1.34", 2396 | "negotiator": "0.6.3" 2397 | } 2398 | }, 2399 | "acorn": { 2400 | "version": "8.7.1", 2401 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz", 2402 | "integrity": "sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A==", 2403 | "dev": true 2404 | }, 2405 | "acorn-walk": { 2406 | "version": "8.2.0", 2407 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 2408 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 2409 | "dev": true 2410 | }, 2411 | "ansi-regex": { 2412 | "version": "5.0.1", 2413 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2414 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2415 | "dev": true 2416 | }, 2417 | "ansi-styles": { 2418 | "version": "4.3.0", 2419 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2420 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2421 | "dev": true, 2422 | "requires": { 2423 | "color-convert": "^2.0.1" 2424 | } 2425 | }, 2426 | "anymatch": { 2427 | "version": "3.1.2", 2428 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 2429 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 2430 | "dev": true, 2431 | "requires": { 2432 | "normalize-path": "^3.0.0", 2433 | "picomatch": "^2.0.4" 2434 | } 2435 | }, 2436 | "arg": { 2437 | "version": "4.1.3", 2438 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 2439 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 2440 | "dev": true 2441 | }, 2442 | "array-flatten": { 2443 | "version": "1.1.1", 2444 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 2445 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 2446 | }, 2447 | "at-least-node": { 2448 | "version": "1.0.0", 2449 | "resolved": "https://registry.npmjs.org/at-least-node/-/at-least-node-1.0.0.tgz", 2450 | "integrity": "sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg==", 2451 | "dev": true 2452 | }, 2453 | "balanced-match": { 2454 | "version": "1.0.2", 2455 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2456 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2457 | "dev": true 2458 | }, 2459 | "binary-extensions": { 2460 | "version": "2.2.0", 2461 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2462 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 2463 | "dev": true 2464 | }, 2465 | "bluebird": { 2466 | "version": "3.7.2", 2467 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 2468 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", 2469 | "dev": true 2470 | }, 2471 | "body-parser": { 2472 | "version": "1.20.0", 2473 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz", 2474 | "integrity": "sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg==", 2475 | "requires": { 2476 | "bytes": "3.1.2", 2477 | "content-type": "~1.0.4", 2478 | "debug": "2.6.9", 2479 | "depd": "2.0.0", 2480 | "destroy": "1.2.0", 2481 | "http-errors": "2.0.0", 2482 | "iconv-lite": "0.4.24", 2483 | "on-finished": "2.4.1", 2484 | "qs": "6.10.3", 2485 | "raw-body": "2.5.1", 2486 | "type-is": "~1.6.18", 2487 | "unpipe": "1.0.0" 2488 | } 2489 | }, 2490 | "brace-expansion": { 2491 | "version": "1.1.11", 2492 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2493 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2494 | "dev": true, 2495 | "requires": { 2496 | "balanced-match": "^1.0.0", 2497 | "concat-map": "0.0.1" 2498 | } 2499 | }, 2500 | "braces": { 2501 | "version": "3.0.2", 2502 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2503 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2504 | "dev": true, 2505 | "requires": { 2506 | "fill-range": "^7.0.1" 2507 | } 2508 | }, 2509 | "buffer-from": { 2510 | "version": "1.1.2", 2511 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 2512 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 2513 | "dev": true 2514 | }, 2515 | "buffer-writer": { 2516 | "version": "2.0.0", 2517 | "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz", 2518 | "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw==" 2519 | }, 2520 | "bytes": { 2521 | "version": "3.1.2", 2522 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 2523 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" 2524 | }, 2525 | "call-bind": { 2526 | "version": "1.0.2", 2527 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 2528 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 2529 | "requires": { 2530 | "function-bind": "^1.1.1", 2531 | "get-intrinsic": "^1.0.2" 2532 | } 2533 | }, 2534 | "chokidar": { 2535 | "version": "3.5.3", 2536 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 2537 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 2538 | "dev": true, 2539 | "requires": { 2540 | "anymatch": "~3.1.2", 2541 | "braces": "~3.0.2", 2542 | "fsevents": "~2.3.2", 2543 | "glob-parent": "~5.1.2", 2544 | "is-binary-path": "~2.1.0", 2545 | "is-glob": "~4.0.1", 2546 | "normalize-path": "~3.0.0", 2547 | "readdirp": "~3.6.0" 2548 | } 2549 | }, 2550 | "cli-color": { 2551 | "version": "2.0.2", 2552 | "resolved": "https://registry.npmjs.org/cli-color/-/cli-color-2.0.2.tgz", 2553 | "integrity": "sha512-g4JYjrTW9MGtCziFNjkqp3IMpGhnJyeB0lOtRPjQkYhXzKYr6tYnXKyEVnMzITxhpbahsEW9KsxOYIDKwcsIBw==", 2554 | "dev": true, 2555 | "requires": { 2556 | "d": "^1.0.1", 2557 | "es5-ext": "^0.10.59", 2558 | "es6-iterator": "^2.0.3", 2559 | "memoizee": "^0.4.15", 2560 | "timers-ext": "^0.1.7" 2561 | } 2562 | }, 2563 | "cliui": { 2564 | "version": "7.0.4", 2565 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2566 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2567 | "dev": true, 2568 | "requires": { 2569 | "string-width": "^4.2.0", 2570 | "strip-ansi": "^6.0.0", 2571 | "wrap-ansi": "^7.0.0" 2572 | } 2573 | }, 2574 | "color-convert": { 2575 | "version": "2.0.1", 2576 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2577 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2578 | "dev": true, 2579 | "requires": { 2580 | "color-name": "~1.1.4" 2581 | } 2582 | }, 2583 | "color-name": { 2584 | "version": "1.1.4", 2585 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2586 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2587 | "dev": true 2588 | }, 2589 | "commander": { 2590 | "version": "2.20.3", 2591 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 2592 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 2593 | "dev": true 2594 | }, 2595 | "concat-map": { 2596 | "version": "0.0.1", 2597 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2598 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2599 | "dev": true 2600 | }, 2601 | "config-chain": { 2602 | "version": "1.1.13", 2603 | "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.13.tgz", 2604 | "integrity": "sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==", 2605 | "dev": true, 2606 | "requires": { 2607 | "ini": "^1.3.4", 2608 | "proto-list": "~1.2.1" 2609 | } 2610 | }, 2611 | "content-disposition": { 2612 | "version": "0.5.4", 2613 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 2614 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 2615 | "requires": { 2616 | "safe-buffer": "5.2.1" 2617 | } 2618 | }, 2619 | "content-type": { 2620 | "version": "1.0.4", 2621 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 2622 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 2623 | }, 2624 | "cookie": { 2625 | "version": "0.5.0", 2626 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 2627 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==" 2628 | }, 2629 | "cookie-signature": { 2630 | "version": "1.0.6", 2631 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 2632 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 2633 | }, 2634 | "create-require": { 2635 | "version": "1.1.1", 2636 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 2637 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 2638 | "dev": true 2639 | }, 2640 | "d": { 2641 | "version": "1.0.1", 2642 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", 2643 | "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", 2644 | "dev": true, 2645 | "requires": { 2646 | "es5-ext": "^0.10.50", 2647 | "type": "^1.0.1" 2648 | } 2649 | }, 2650 | "debug": { 2651 | "version": "2.6.9", 2652 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2653 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2654 | "requires": { 2655 | "ms": "2.0.0" 2656 | } 2657 | }, 2658 | "depd": { 2659 | "version": "2.0.0", 2660 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 2661 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 2662 | }, 2663 | "destroy": { 2664 | "version": "1.2.0", 2665 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 2666 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" 2667 | }, 2668 | "diff": { 2669 | "version": "4.0.2", 2670 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 2671 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 2672 | "dev": true 2673 | }, 2674 | "dotenv": { 2675 | "version": "16.0.1", 2676 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz", 2677 | "integrity": "sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ==" 2678 | }, 2679 | "dottie": { 2680 | "version": "2.0.2", 2681 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.2.tgz", 2682 | "integrity": "sha512-fmrwR04lsniq/uSr8yikThDTrM7epXHBAAjH9TbeH3rEA8tdCO7mRzB9hdmdGyJCxF8KERo9CITcm3kGuoyMhg==" 2683 | }, 2684 | "dynamic-dedupe": { 2685 | "version": "0.3.0", 2686 | "resolved": "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz", 2687 | "integrity": "sha512-ssuANeD+z97meYOqd50e04Ze5qp4bPqo8cCkI4TRjZkzAUgIDTrXV1R8QCdINpiI+hw14+rYazvTRdQrz0/rFQ==", 2688 | "dev": true, 2689 | "requires": { 2690 | "xtend": "^4.0.0" 2691 | } 2692 | }, 2693 | "editorconfig": { 2694 | "version": "0.15.3", 2695 | "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", 2696 | "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", 2697 | "dev": true, 2698 | "requires": { 2699 | "commander": "^2.19.0", 2700 | "lru-cache": "^4.1.5", 2701 | "semver": "^5.6.0", 2702 | "sigmund": "^1.0.1" 2703 | }, 2704 | "dependencies": { 2705 | "lru-cache": { 2706 | "version": "4.1.5", 2707 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 2708 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 2709 | "dev": true, 2710 | "requires": { 2711 | "pseudomap": "^1.0.2", 2712 | "yallist": "^2.1.2" 2713 | } 2714 | }, 2715 | "semver": { 2716 | "version": "5.7.1", 2717 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2718 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 2719 | "dev": true 2720 | }, 2721 | "yallist": { 2722 | "version": "2.1.2", 2723 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 2724 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 2725 | "dev": true 2726 | } 2727 | } 2728 | }, 2729 | "ee-first": { 2730 | "version": "1.1.1", 2731 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 2732 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 2733 | }, 2734 | "emoji-regex": { 2735 | "version": "8.0.0", 2736 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2737 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2738 | "dev": true 2739 | }, 2740 | "encodeurl": { 2741 | "version": "1.0.2", 2742 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2743 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" 2744 | }, 2745 | "es5-ext": { 2746 | "version": "0.10.61", 2747 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.61.tgz", 2748 | "integrity": "sha512-yFhIqQAzu2Ca2I4SE2Au3rxVfmohU9Y7wqGR+s7+H7krk26NXhIRAZDgqd6xqjCEFUomDEA3/Bo/7fKmIkW1kA==", 2749 | "dev": true, 2750 | "requires": { 2751 | "es6-iterator": "^2.0.3", 2752 | "es6-symbol": "^3.1.3", 2753 | "next-tick": "^1.1.0" 2754 | } 2755 | }, 2756 | "es6-iterator": { 2757 | "version": "2.0.3", 2758 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 2759 | "integrity": "sha512-zw4SRzoUkd+cl+ZoE15A9o1oQd920Bb0iOJMQkQhl3jNc03YqVjAhG7scf9C5KWRU/R13Orf588uCC6525o02g==", 2760 | "dev": true, 2761 | "requires": { 2762 | "d": "1", 2763 | "es5-ext": "^0.10.35", 2764 | "es6-symbol": "^3.1.1" 2765 | } 2766 | }, 2767 | "es6-symbol": { 2768 | "version": "3.1.3", 2769 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", 2770 | "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", 2771 | "dev": true, 2772 | "requires": { 2773 | "d": "^1.0.1", 2774 | "ext": "^1.1.2" 2775 | } 2776 | }, 2777 | "es6-weak-map": { 2778 | "version": "2.0.3", 2779 | "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.3.tgz", 2780 | "integrity": "sha512-p5um32HOTO1kP+w7PRnB+5lQ43Z6muuMuIMffvDN8ZB4GcnjLBV6zGStpbASIMk4DCAvEaamhe2zhyCb/QXXsA==", 2781 | "dev": true, 2782 | "requires": { 2783 | "d": "1", 2784 | "es5-ext": "^0.10.46", 2785 | "es6-iterator": "^2.0.3", 2786 | "es6-symbol": "^3.1.1" 2787 | } 2788 | }, 2789 | "escalade": { 2790 | "version": "3.1.1", 2791 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2792 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2793 | "dev": true 2794 | }, 2795 | "escape-html": { 2796 | "version": "1.0.3", 2797 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2798 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 2799 | }, 2800 | "etag": { 2801 | "version": "1.8.1", 2802 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 2803 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==" 2804 | }, 2805 | "event-emitter": { 2806 | "version": "0.3.5", 2807 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 2808 | "integrity": "sha512-D9rRn9y7kLPnJ+hMq7S/nhvoKwwvVJahBi2BPmx3bvbsEdK3W9ii8cBSGjP+72/LnM4n6fo3+dkCX5FeTQruXA==", 2809 | "dev": true, 2810 | "requires": { 2811 | "d": "1", 2812 | "es5-ext": "~0.10.14" 2813 | } 2814 | }, 2815 | "express": { 2816 | "version": "4.18.1", 2817 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.1.tgz", 2818 | "integrity": "sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q==", 2819 | "requires": { 2820 | "accepts": "~1.3.8", 2821 | "array-flatten": "1.1.1", 2822 | "body-parser": "1.20.0", 2823 | "content-disposition": "0.5.4", 2824 | "content-type": "~1.0.4", 2825 | "cookie": "0.5.0", 2826 | "cookie-signature": "1.0.6", 2827 | "debug": "2.6.9", 2828 | "depd": "2.0.0", 2829 | "encodeurl": "~1.0.2", 2830 | "escape-html": "~1.0.3", 2831 | "etag": "~1.8.1", 2832 | "finalhandler": "1.2.0", 2833 | "fresh": "0.5.2", 2834 | "http-errors": "2.0.0", 2835 | "merge-descriptors": "1.0.1", 2836 | "methods": "~1.1.2", 2837 | "on-finished": "2.4.1", 2838 | "parseurl": "~1.3.3", 2839 | "path-to-regexp": "0.1.7", 2840 | "proxy-addr": "~2.0.7", 2841 | "qs": "6.10.3", 2842 | "range-parser": "~1.2.1", 2843 | "safe-buffer": "5.2.1", 2844 | "send": "0.18.0", 2845 | "serve-static": "1.15.0", 2846 | "setprototypeof": "1.2.0", 2847 | "statuses": "2.0.1", 2848 | "type-is": "~1.6.18", 2849 | "utils-merge": "1.0.1", 2850 | "vary": "~1.1.2" 2851 | } 2852 | }, 2853 | "ext": { 2854 | "version": "1.6.0", 2855 | "resolved": "https://registry.npmjs.org/ext/-/ext-1.6.0.tgz", 2856 | "integrity": "sha512-sdBImtzkq2HpkdRLtlLWDa6w4DX22ijZLKx8BMPUuKe1c5lbN6xwQDQCxSfxBQnHZ13ls/FH0MQZx/q/gr6FQg==", 2857 | "dev": true, 2858 | "requires": { 2859 | "type": "^2.5.0" 2860 | }, 2861 | "dependencies": { 2862 | "type": { 2863 | "version": "2.6.0", 2864 | "resolved": "https://registry.npmjs.org/type/-/type-2.6.0.tgz", 2865 | "integrity": "sha512-eiDBDOmkih5pMbo9OqsqPRGMljLodLcwd5XD5JbtNB0o89xZAwynY9EdCDsJU7LtcVCClu9DvM7/0Ep1hYX3EQ==", 2866 | "dev": true 2867 | } 2868 | } 2869 | }, 2870 | "fill-range": { 2871 | "version": "7.0.1", 2872 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2873 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2874 | "dev": true, 2875 | "requires": { 2876 | "to-regex-range": "^5.0.1" 2877 | } 2878 | }, 2879 | "finalhandler": { 2880 | "version": "1.2.0", 2881 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 2882 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 2883 | "requires": { 2884 | "debug": "2.6.9", 2885 | "encodeurl": "~1.0.2", 2886 | "escape-html": "~1.0.3", 2887 | "on-finished": "2.4.1", 2888 | "parseurl": "~1.3.3", 2889 | "statuses": "2.0.1", 2890 | "unpipe": "~1.0.0" 2891 | } 2892 | }, 2893 | "forwarded": { 2894 | "version": "0.2.0", 2895 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 2896 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 2897 | }, 2898 | "fresh": { 2899 | "version": "0.5.2", 2900 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 2901 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" 2902 | }, 2903 | "fs-extra": { 2904 | "version": "9.1.0", 2905 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", 2906 | "integrity": "sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==", 2907 | "dev": true, 2908 | "requires": { 2909 | "at-least-node": "^1.0.0", 2910 | "graceful-fs": "^4.2.0", 2911 | "jsonfile": "^6.0.1", 2912 | "universalify": "^2.0.0" 2913 | } 2914 | }, 2915 | "fs.realpath": { 2916 | "version": "1.0.0", 2917 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2918 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2919 | "dev": true 2920 | }, 2921 | "fsevents": { 2922 | "version": "2.3.2", 2923 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2924 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2925 | "dev": true, 2926 | "optional": true 2927 | }, 2928 | "function-bind": { 2929 | "version": "1.1.1", 2930 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2931 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2932 | }, 2933 | "get-caller-file": { 2934 | "version": "2.0.5", 2935 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2936 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2937 | "dev": true 2938 | }, 2939 | "get-intrinsic": { 2940 | "version": "1.1.1", 2941 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 2942 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 2943 | "requires": { 2944 | "function-bind": "^1.1.1", 2945 | "has": "^1.0.3", 2946 | "has-symbols": "^1.0.1" 2947 | } 2948 | }, 2949 | "glob": { 2950 | "version": "7.2.3", 2951 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2952 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2953 | "dev": true, 2954 | "requires": { 2955 | "fs.realpath": "^1.0.0", 2956 | "inflight": "^1.0.4", 2957 | "inherits": "2", 2958 | "minimatch": "^3.1.1", 2959 | "once": "^1.3.0", 2960 | "path-is-absolute": "^1.0.0" 2961 | } 2962 | }, 2963 | "glob-parent": { 2964 | "version": "5.1.2", 2965 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2966 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2967 | "dev": true, 2968 | "requires": { 2969 | "is-glob": "^4.0.1" 2970 | } 2971 | }, 2972 | "graceful-fs": { 2973 | "version": "4.2.10", 2974 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", 2975 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", 2976 | "dev": true 2977 | }, 2978 | "has": { 2979 | "version": "1.0.3", 2980 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2981 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2982 | "requires": { 2983 | "function-bind": "^1.1.1" 2984 | } 2985 | }, 2986 | "has-symbols": { 2987 | "version": "1.0.3", 2988 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2989 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 2990 | }, 2991 | "http-errors": { 2992 | "version": "2.0.0", 2993 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 2994 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 2995 | "requires": { 2996 | "depd": "2.0.0", 2997 | "inherits": "2.0.4", 2998 | "setprototypeof": "1.2.0", 2999 | "statuses": "2.0.1", 3000 | "toidentifier": "1.0.1" 3001 | } 3002 | }, 3003 | "iconv-lite": { 3004 | "version": "0.4.24", 3005 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 3006 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 3007 | "requires": { 3008 | "safer-buffer": ">= 2.1.2 < 3" 3009 | } 3010 | }, 3011 | "inflection": { 3012 | "version": "1.13.2", 3013 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.2.tgz", 3014 | "integrity": "sha512-cmZlljCRTBFouT8UzMzrGcVEvkv6D/wBdcdKG7J1QH5cXjtU75Dm+P27v9EKu/Y43UYyCJd1WC4zLebRrC8NBw==" 3015 | }, 3016 | "inflight": { 3017 | "version": "1.0.6", 3018 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 3019 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 3020 | "dev": true, 3021 | "requires": { 3022 | "once": "^1.3.0", 3023 | "wrappy": "1" 3024 | } 3025 | }, 3026 | "inherits": { 3027 | "version": "2.0.4", 3028 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 3029 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 3030 | }, 3031 | "ini": { 3032 | "version": "1.3.8", 3033 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 3034 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", 3035 | "dev": true 3036 | }, 3037 | "ipaddr.js": { 3038 | "version": "1.9.1", 3039 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 3040 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 3041 | }, 3042 | "is-binary-path": { 3043 | "version": "2.1.0", 3044 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 3045 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 3046 | "dev": true, 3047 | "requires": { 3048 | "binary-extensions": "^2.0.0" 3049 | } 3050 | }, 3051 | "is-core-module": { 3052 | "version": "2.9.0", 3053 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz", 3054 | "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==", 3055 | "dev": true, 3056 | "requires": { 3057 | "has": "^1.0.3" 3058 | } 3059 | }, 3060 | "is-extglob": { 3061 | "version": "2.1.1", 3062 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 3063 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 3064 | "dev": true 3065 | }, 3066 | "is-fullwidth-code-point": { 3067 | "version": "3.0.0", 3068 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 3069 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 3070 | "dev": true 3071 | }, 3072 | "is-glob": { 3073 | "version": "4.0.3", 3074 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 3075 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 3076 | "dev": true, 3077 | "requires": { 3078 | "is-extglob": "^2.1.1" 3079 | } 3080 | }, 3081 | "is-number": { 3082 | "version": "7.0.0", 3083 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 3084 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 3085 | "dev": true 3086 | }, 3087 | "is-promise": { 3088 | "version": "2.2.2", 3089 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.2.2.tgz", 3090 | "integrity": "sha512-+lP4/6lKUBfQjZ2pdxThZvLUAafmZb8OAxFb8XXtiQmS35INgr85hdOGoEs124ez1FCnZJt6jau/T+alh58QFQ==", 3091 | "dev": true 3092 | }, 3093 | "js-beautify": { 3094 | "version": "1.14.3", 3095 | "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.3.tgz", 3096 | "integrity": "sha512-f1ra8PHtOEu/70EBnmiUlV8nJePS58y9qKjl4JHfYWlFH6bo7ogZBz//FAZp7jDuXtYnGYKymZPlrg2I/9Zo4g==", 3097 | "dev": true, 3098 | "requires": { 3099 | "config-chain": "^1.1.13", 3100 | "editorconfig": "^0.15.3", 3101 | "glob": "^7.1.3", 3102 | "nopt": "^5.0.0" 3103 | } 3104 | }, 3105 | "jsonfile": { 3106 | "version": "6.1.0", 3107 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", 3108 | "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", 3109 | "dev": true, 3110 | "requires": { 3111 | "graceful-fs": "^4.1.6", 3112 | "universalify": "^2.0.0" 3113 | } 3114 | }, 3115 | "lodash": { 3116 | "version": "4.17.21", 3117 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 3118 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 3119 | }, 3120 | "lru-cache": { 3121 | "version": "6.0.0", 3122 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3123 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3124 | "requires": { 3125 | "yallist": "^4.0.0" 3126 | } 3127 | }, 3128 | "lru-queue": { 3129 | "version": "0.1.0", 3130 | "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", 3131 | "integrity": "sha512-BpdYkt9EvGl8OfWHDQPISVpcl5xZthb+XPsbELj5AQXxIC8IriDZIQYjBJPEm5rS420sjZ0TLEzRcq5KdBhYrQ==", 3132 | "dev": true, 3133 | "requires": { 3134 | "es5-ext": "~0.10.2" 3135 | } 3136 | }, 3137 | "make-error": { 3138 | "version": "1.3.6", 3139 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 3140 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 3141 | "dev": true 3142 | }, 3143 | "media-typer": { 3144 | "version": "0.3.0", 3145 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 3146 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" 3147 | }, 3148 | "memoizee": { 3149 | "version": "0.4.15", 3150 | "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.15.tgz", 3151 | "integrity": "sha512-UBWmJpLZd5STPm7PMUlOw/TSy972M+z8gcyQ5veOnSDRREz/0bmpyTfKt3/51DhEBqCZQn1udM/5flcSPYhkdQ==", 3152 | "dev": true, 3153 | "requires": { 3154 | "d": "^1.0.1", 3155 | "es5-ext": "^0.10.53", 3156 | "es6-weak-map": "^2.0.3", 3157 | "event-emitter": "^0.3.5", 3158 | "is-promise": "^2.2.2", 3159 | "lru-queue": "^0.1.0", 3160 | "next-tick": "^1.1.0", 3161 | "timers-ext": "^0.1.7" 3162 | } 3163 | }, 3164 | "merge-descriptors": { 3165 | "version": "1.0.1", 3166 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 3167 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 3168 | }, 3169 | "methods": { 3170 | "version": "1.1.2", 3171 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 3172 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==" 3173 | }, 3174 | "mime": { 3175 | "version": "1.6.0", 3176 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 3177 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 3178 | }, 3179 | "mime-db": { 3180 | "version": "1.52.0", 3181 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 3182 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 3183 | }, 3184 | "mime-types": { 3185 | "version": "2.1.35", 3186 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 3187 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 3188 | "requires": { 3189 | "mime-db": "1.52.0" 3190 | } 3191 | }, 3192 | "minimatch": { 3193 | "version": "3.1.2", 3194 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3195 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3196 | "dev": true, 3197 | "requires": { 3198 | "brace-expansion": "^1.1.7" 3199 | } 3200 | }, 3201 | "minimist": { 3202 | "version": "1.2.6", 3203 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 3204 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 3205 | "dev": true 3206 | }, 3207 | "mkdirp": { 3208 | "version": "1.0.4", 3209 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 3210 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 3211 | "dev": true 3212 | }, 3213 | "moment": { 3214 | "version": "2.29.3", 3215 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.3.tgz", 3216 | "integrity": "sha512-c6YRvhEo//6T2Jz/vVtYzqBzwvPT95JBQ+smCytzf7c50oMZRsR/a4w88aD34I+/QVSfnoAnSBFPJHItlOMJVw==" 3217 | }, 3218 | "moment-timezone": { 3219 | "version": "0.5.34", 3220 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.34.tgz", 3221 | "integrity": "sha512-3zAEHh2hKUs3EXLESx/wsgw6IQdusOT8Bxm3D9UrHPQR7zlMmzwybC8zHEM1tQ4LJwP7fcxrWr8tuBg05fFCbg==", 3222 | "requires": { 3223 | "moment": ">= 2.9.0" 3224 | } 3225 | }, 3226 | "ms": { 3227 | "version": "2.0.0", 3228 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 3229 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 3230 | }, 3231 | "negotiator": { 3232 | "version": "0.6.3", 3233 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 3234 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 3235 | }, 3236 | "next-tick": { 3237 | "version": "1.1.0", 3238 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.1.0.tgz", 3239 | "integrity": "sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ==", 3240 | "dev": true 3241 | }, 3242 | "nopt": { 3243 | "version": "5.0.0", 3244 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 3245 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 3246 | "dev": true, 3247 | "requires": { 3248 | "abbrev": "1" 3249 | } 3250 | }, 3251 | "normalize-path": { 3252 | "version": "3.0.0", 3253 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 3254 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 3255 | "dev": true 3256 | }, 3257 | "object-inspect": { 3258 | "version": "1.12.2", 3259 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", 3260 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==" 3261 | }, 3262 | "on-finished": { 3263 | "version": "2.4.1", 3264 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 3265 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 3266 | "requires": { 3267 | "ee-first": "1.1.1" 3268 | } 3269 | }, 3270 | "once": { 3271 | "version": "1.4.0", 3272 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3273 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3274 | "dev": true, 3275 | "requires": { 3276 | "wrappy": "1" 3277 | } 3278 | }, 3279 | "packet-reader": { 3280 | "version": "1.0.0", 3281 | "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz", 3282 | "integrity": "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ==" 3283 | }, 3284 | "parseurl": { 3285 | "version": "1.3.3", 3286 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 3287 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 3288 | }, 3289 | "path-is-absolute": { 3290 | "version": "1.0.1", 3291 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3292 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3293 | "dev": true 3294 | }, 3295 | "path-parse": { 3296 | "version": "1.0.7", 3297 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3298 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 3299 | "dev": true 3300 | }, 3301 | "path-to-regexp": { 3302 | "version": "0.1.7", 3303 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 3304 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 3305 | }, 3306 | "pg": { 3307 | "version": "8.7.3", 3308 | "resolved": "https://registry.npmjs.org/pg/-/pg-8.7.3.tgz", 3309 | "integrity": "sha512-HPmH4GH4H3AOprDJOazoIcpI49XFsHCe8xlrjHkWiapdbHK+HLtbm/GQzXYAZwmPju/kzKhjaSfMACG+8cgJcw==", 3310 | "requires": { 3311 | "buffer-writer": "2.0.0", 3312 | "packet-reader": "1.0.0", 3313 | "pg-connection-string": "^2.5.0", 3314 | "pg-pool": "^3.5.1", 3315 | "pg-protocol": "^1.5.0", 3316 | "pg-types": "^2.1.0", 3317 | "pgpass": "1.x" 3318 | } 3319 | }, 3320 | "pg-connection-string": { 3321 | "version": "2.5.0", 3322 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.5.0.tgz", 3323 | "integrity": "sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ==" 3324 | }, 3325 | "pg-int8": { 3326 | "version": "1.0.1", 3327 | "resolved": "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz", 3328 | "integrity": "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw==" 3329 | }, 3330 | "pg-pool": { 3331 | "version": "3.5.1", 3332 | "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-3.5.1.tgz", 3333 | "integrity": "sha512-6iCR0wVrro6OOHFsyavV+i6KYL4lVNyYAB9RD18w66xSzN+d8b66HiwuP30Gp1SH5O9T82fckkzsRjlrhD0ioQ==", 3334 | "requires": {} 3335 | }, 3336 | "pg-protocol": { 3337 | "version": "1.5.0", 3338 | "resolved": "https://registry.npmjs.org/pg-protocol/-/pg-protocol-1.5.0.tgz", 3339 | "integrity": "sha512-muRttij7H8TqRNu/DxrAJQITO4Ac7RmX3Klyr/9mJEOBeIpgnF8f9jAfRz5d3XwQZl5qBjF9gLsUtMPJE0vezQ==" 3340 | }, 3341 | "pg-types": { 3342 | "version": "2.2.0", 3343 | "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-2.2.0.tgz", 3344 | "integrity": "sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA==", 3345 | "requires": { 3346 | "pg-int8": "1.0.1", 3347 | "postgres-array": "~2.0.0", 3348 | "postgres-bytea": "~1.0.0", 3349 | "postgres-date": "~1.0.4", 3350 | "postgres-interval": "^1.1.0" 3351 | } 3352 | }, 3353 | "pgpass": { 3354 | "version": "1.0.5", 3355 | "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.5.tgz", 3356 | "integrity": "sha512-FdW9r/jQZhSeohs1Z3sI1yxFQNFvMcnmfuj4WBMUTxOrAyLMaTcE1aAMBiTlbMNaXvBCQuVi0R7hd8udDSP7ug==", 3357 | "requires": { 3358 | "split2": "^4.1.0" 3359 | } 3360 | }, 3361 | "picomatch": { 3362 | "version": "2.3.1", 3363 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3364 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3365 | "dev": true 3366 | }, 3367 | "postgres-array": { 3368 | "version": "2.0.0", 3369 | "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz", 3370 | "integrity": "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA==" 3371 | }, 3372 | "postgres-bytea": { 3373 | "version": "1.0.0", 3374 | "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz", 3375 | "integrity": "sha512-xy3pmLuQqRBZBXDULy7KbaitYqLcmxigw14Q5sj8QBVLqEwXfeybIKVWiqAXTlcvdvb0+xkOtDbfQMOf4lST1w==" 3376 | }, 3377 | "postgres-date": { 3378 | "version": "1.0.7", 3379 | "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.7.tgz", 3380 | "integrity": "sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q==" 3381 | }, 3382 | "postgres-interval": { 3383 | "version": "1.2.0", 3384 | "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz", 3385 | "integrity": "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==", 3386 | "requires": { 3387 | "xtend": "^4.0.0" 3388 | } 3389 | }, 3390 | "proto-list": { 3391 | "version": "1.2.4", 3392 | "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", 3393 | "integrity": "sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk=", 3394 | "dev": true 3395 | }, 3396 | "proxy-addr": { 3397 | "version": "2.0.7", 3398 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 3399 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 3400 | "requires": { 3401 | "forwarded": "0.2.0", 3402 | "ipaddr.js": "1.9.1" 3403 | } 3404 | }, 3405 | "pseudomap": { 3406 | "version": "1.0.2", 3407 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 3408 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 3409 | "dev": true 3410 | }, 3411 | "qs": { 3412 | "version": "6.10.3", 3413 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz", 3414 | "integrity": "sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ==", 3415 | "requires": { 3416 | "side-channel": "^1.0.4" 3417 | } 3418 | }, 3419 | "range-parser": { 3420 | "version": "1.2.1", 3421 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 3422 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 3423 | }, 3424 | "raw-body": { 3425 | "version": "2.5.1", 3426 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 3427 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 3428 | "requires": { 3429 | "bytes": "3.1.2", 3430 | "http-errors": "2.0.0", 3431 | "iconv-lite": "0.4.24", 3432 | "unpipe": "1.0.0" 3433 | } 3434 | }, 3435 | "readdirp": { 3436 | "version": "3.6.0", 3437 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3438 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3439 | "dev": true, 3440 | "requires": { 3441 | "picomatch": "^2.2.1" 3442 | } 3443 | }, 3444 | "require-directory": { 3445 | "version": "2.1.1", 3446 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3447 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 3448 | "dev": true 3449 | }, 3450 | "resolve": { 3451 | "version": "1.22.0", 3452 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 3453 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 3454 | "dev": true, 3455 | "requires": { 3456 | "is-core-module": "^2.8.1", 3457 | "path-parse": "^1.0.7", 3458 | "supports-preserve-symlinks-flag": "^1.0.0" 3459 | } 3460 | }, 3461 | "retry-as-promised": { 3462 | "version": "5.0.0", 3463 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-5.0.0.tgz", 3464 | "integrity": "sha512-6S+5LvtTl2ggBumk04hBo/4Uf6fRJUwIgunGZ7CYEBCeufGFW1Pu6ucUf/UskHeWOIsUcLOGLFXPig5tR5V1nA==" 3465 | }, 3466 | "rimraf": { 3467 | "version": "2.7.1", 3468 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 3469 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 3470 | "dev": true, 3471 | "requires": { 3472 | "glob": "^7.1.3" 3473 | } 3474 | }, 3475 | "safe-buffer": { 3476 | "version": "5.2.1", 3477 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3478 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 3479 | }, 3480 | "safer-buffer": { 3481 | "version": "2.1.2", 3482 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 3483 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 3484 | }, 3485 | "semver": { 3486 | "version": "7.3.7", 3487 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 3488 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 3489 | "requires": { 3490 | "lru-cache": "^6.0.0" 3491 | } 3492 | }, 3493 | "send": { 3494 | "version": "0.18.0", 3495 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 3496 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 3497 | "requires": { 3498 | "debug": "2.6.9", 3499 | "depd": "2.0.0", 3500 | "destroy": "1.2.0", 3501 | "encodeurl": "~1.0.2", 3502 | "escape-html": "~1.0.3", 3503 | "etag": "~1.8.1", 3504 | "fresh": "0.5.2", 3505 | "http-errors": "2.0.0", 3506 | "mime": "1.6.0", 3507 | "ms": "2.1.3", 3508 | "on-finished": "2.4.1", 3509 | "range-parser": "~1.2.1", 3510 | "statuses": "2.0.1" 3511 | }, 3512 | "dependencies": { 3513 | "ms": { 3514 | "version": "2.1.3", 3515 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 3516 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 3517 | } 3518 | } 3519 | }, 3520 | "sequelize": { 3521 | "version": "6.20.1", 3522 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.20.1.tgz", 3523 | "integrity": "sha512-1YBMv++Yy1JBFFiac1Xoa+Km5qV6YI1ckdkW0xyD7IpLMtE5JmjgZdZXGfwgRUNjhaKMxdzT+nkvJgeXO0rv/g==", 3524 | "requires": { 3525 | "@types/debug": "^4.1.7", 3526 | "@types/validator": "^13.7.1", 3527 | "debug": "^4.3.3", 3528 | "dottie": "^2.0.2", 3529 | "inflection": "^1.13.2", 3530 | "lodash": "^4.17.21", 3531 | "moment": "^2.29.1", 3532 | "moment-timezone": "^0.5.34", 3533 | "pg-connection-string": "^2.5.0", 3534 | "retry-as-promised": "^5.0.0", 3535 | "semver": "^7.3.5", 3536 | "sequelize-pool": "^7.1.0", 3537 | "toposort-class": "^1.0.1", 3538 | "uuid": "^8.3.2", 3539 | "validator": "^13.7.0", 3540 | "wkx": "^0.5.0" 3541 | }, 3542 | "dependencies": { 3543 | "debug": { 3544 | "version": "4.3.4", 3545 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 3546 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 3547 | "requires": { 3548 | "ms": "2.1.2" 3549 | } 3550 | }, 3551 | "ms": { 3552 | "version": "2.1.2", 3553 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3554 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 3555 | } 3556 | } 3557 | }, 3558 | "sequelize-cli": { 3559 | "version": "6.4.1", 3560 | "resolved": "https://registry.npmjs.org/sequelize-cli/-/sequelize-cli-6.4.1.tgz", 3561 | "integrity": "sha512-gIzzFitUGUErq6DYd1JDnsmx7z7XcxzRNe4Py3AqeaxcyjpCAZU2BQnsNPGPMKAaXfMtKi/d9Tu4MtLrehVzIQ==", 3562 | "dev": true, 3563 | "requires": { 3564 | "cli-color": "^2.0.1", 3565 | "fs-extra": "^9.1.0", 3566 | "js-beautify": "^1.14.0", 3567 | "lodash": "^4.17.21", 3568 | "resolve": "^1.20.0", 3569 | "umzug": "^2.3.0", 3570 | "yargs": "^16.2.0" 3571 | } 3572 | }, 3573 | "sequelize-pool": { 3574 | "version": "7.1.0", 3575 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-7.1.0.tgz", 3576 | "integrity": "sha512-G9c0qlIWQSK29pR/5U2JF5dDQeqqHRragoyahj/Nx4KOOQ3CPPfzxnfqFPCSB7x5UgjOgnZ61nSxz+fjDpRlJg==" 3577 | }, 3578 | "serve-static": { 3579 | "version": "1.15.0", 3580 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 3581 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 3582 | "requires": { 3583 | "encodeurl": "~1.0.2", 3584 | "escape-html": "~1.0.3", 3585 | "parseurl": "~1.3.3", 3586 | "send": "0.18.0" 3587 | } 3588 | }, 3589 | "setprototypeof": { 3590 | "version": "1.2.0", 3591 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 3592 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 3593 | }, 3594 | "side-channel": { 3595 | "version": "1.0.4", 3596 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 3597 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 3598 | "requires": { 3599 | "call-bind": "^1.0.0", 3600 | "get-intrinsic": "^1.0.2", 3601 | "object-inspect": "^1.9.0" 3602 | } 3603 | }, 3604 | "sigmund": { 3605 | "version": "1.0.1", 3606 | "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", 3607 | "integrity": "sha1-P/IfGYytIXX587eBhT/ZTQ0ZtZA=", 3608 | "dev": true 3609 | }, 3610 | "source-map": { 3611 | "version": "0.6.1", 3612 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3613 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3614 | "dev": true 3615 | }, 3616 | "source-map-support": { 3617 | "version": "0.5.21", 3618 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 3619 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 3620 | "dev": true, 3621 | "requires": { 3622 | "buffer-from": "^1.0.0", 3623 | "source-map": "^0.6.0" 3624 | } 3625 | }, 3626 | "split2": { 3627 | "version": "4.1.0", 3628 | "resolved": "https://registry.npmjs.org/split2/-/split2-4.1.0.tgz", 3629 | "integrity": "sha512-VBiJxFkxiXRlUIeyMQi8s4hgvKCSjtknJv/LVYbrgALPwf5zSKmEwV9Lst25AkvMDnvxODugjdl6KZgwKM1WYQ==" 3630 | }, 3631 | "statuses": { 3632 | "version": "2.0.1", 3633 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 3634 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" 3635 | }, 3636 | "string-width": { 3637 | "version": "4.2.3", 3638 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3639 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3640 | "dev": true, 3641 | "requires": { 3642 | "emoji-regex": "^8.0.0", 3643 | "is-fullwidth-code-point": "^3.0.0", 3644 | "strip-ansi": "^6.0.1" 3645 | } 3646 | }, 3647 | "strip-ansi": { 3648 | "version": "6.0.1", 3649 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3650 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3651 | "dev": true, 3652 | "requires": { 3653 | "ansi-regex": "^5.0.1" 3654 | } 3655 | }, 3656 | "strip-bom": { 3657 | "version": "3.0.0", 3658 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3659 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 3660 | "dev": true 3661 | }, 3662 | "strip-json-comments": { 3663 | "version": "2.0.1", 3664 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 3665 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 3666 | "dev": true 3667 | }, 3668 | "supports-preserve-symlinks-flag": { 3669 | "version": "1.0.0", 3670 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3671 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3672 | "dev": true 3673 | }, 3674 | "timers-ext": { 3675 | "version": "0.1.7", 3676 | "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.7.tgz", 3677 | "integrity": "sha512-b85NUNzTSdodShTIbky6ZF02e8STtVVfD+fu4aXXShEELpozH+bCpJLYMPZbsABN2wDH7fJpqIoXxJpzbf0NqQ==", 3678 | "dev": true, 3679 | "requires": { 3680 | "es5-ext": "~0.10.46", 3681 | "next-tick": "1" 3682 | } 3683 | }, 3684 | "to-regex-range": { 3685 | "version": "5.0.1", 3686 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3687 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3688 | "dev": true, 3689 | "requires": { 3690 | "is-number": "^7.0.0" 3691 | } 3692 | }, 3693 | "toidentifier": { 3694 | "version": "1.0.1", 3695 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 3696 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 3697 | }, 3698 | "toposort-class": { 3699 | "version": "1.0.1", 3700 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 3701 | "integrity": "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg=" 3702 | }, 3703 | "tree-kill": { 3704 | "version": "1.2.2", 3705 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", 3706 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", 3707 | "dev": true 3708 | }, 3709 | "ts-node": { 3710 | "version": "10.8.0", 3711 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.8.0.tgz", 3712 | "integrity": "sha512-/fNd5Qh+zTt8Vt1KbYZjRHCE9sI5i7nqfD/dzBBRDeVXZXS6kToW6R7tTU6Nd4XavFs0mAVCg29Q//ML7WsZYA==", 3713 | "dev": true, 3714 | "requires": { 3715 | "@cspotcode/source-map-support": "^0.8.0", 3716 | "@tsconfig/node10": "^1.0.7", 3717 | "@tsconfig/node12": "^1.0.7", 3718 | "@tsconfig/node14": "^1.0.0", 3719 | "@tsconfig/node16": "^1.0.2", 3720 | "acorn": "^8.4.1", 3721 | "acorn-walk": "^8.1.1", 3722 | "arg": "^4.1.0", 3723 | "create-require": "^1.1.0", 3724 | "diff": "^4.0.1", 3725 | "make-error": "^1.1.1", 3726 | "v8-compile-cache-lib": "^3.0.1", 3727 | "yn": "3.1.1" 3728 | } 3729 | }, 3730 | "ts-node-dev": { 3731 | "version": "2.0.0", 3732 | "resolved": "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz", 3733 | "integrity": "sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w==", 3734 | "dev": true, 3735 | "requires": { 3736 | "chokidar": "^3.5.1", 3737 | "dynamic-dedupe": "^0.3.0", 3738 | "minimist": "^1.2.6", 3739 | "mkdirp": "^1.0.4", 3740 | "resolve": "^1.0.0", 3741 | "rimraf": "^2.6.1", 3742 | "source-map-support": "^0.5.12", 3743 | "tree-kill": "^1.2.2", 3744 | "ts-node": "^10.4.0", 3745 | "tsconfig": "^7.0.0" 3746 | } 3747 | }, 3748 | "tsconfig": { 3749 | "version": "7.0.0", 3750 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz", 3751 | "integrity": "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==", 3752 | "dev": true, 3753 | "requires": { 3754 | "@types/strip-bom": "^3.0.0", 3755 | "@types/strip-json-comments": "0.0.30", 3756 | "strip-bom": "^3.0.0", 3757 | "strip-json-comments": "^2.0.0" 3758 | } 3759 | }, 3760 | "type": { 3761 | "version": "1.2.0", 3762 | "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", 3763 | "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==", 3764 | "dev": true 3765 | }, 3766 | "type-is": { 3767 | "version": "1.6.18", 3768 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 3769 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 3770 | "requires": { 3771 | "media-typer": "0.3.0", 3772 | "mime-types": "~2.1.24" 3773 | } 3774 | }, 3775 | "typescript": { 3776 | "version": "4.7.2", 3777 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.7.2.tgz", 3778 | "integrity": "sha512-Mamb1iX2FDUpcTRzltPxgWMKy3fhg0TN378ylbktPGPK/99KbDtMQ4W1hwgsbPAsG3a0xKa1vmw4VKZQbkvz5A==", 3779 | "dev": true 3780 | }, 3781 | "umzug": { 3782 | "version": "2.3.0", 3783 | "resolved": "https://registry.npmjs.org/umzug/-/umzug-2.3.0.tgz", 3784 | "integrity": "sha512-Z274K+e8goZK8QJxmbRPhl89HPO1K+ORFtm6rySPhFKfKc5GHhqdzD0SGhSWHkzoXasqJuItdhorSvY7/Cgflw==", 3785 | "dev": true, 3786 | "requires": { 3787 | "bluebird": "^3.7.2" 3788 | } 3789 | }, 3790 | "universalify": { 3791 | "version": "2.0.0", 3792 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.0.tgz", 3793 | "integrity": "sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==", 3794 | "dev": true 3795 | }, 3796 | "unpipe": { 3797 | "version": "1.0.0", 3798 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3799 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 3800 | }, 3801 | "utils-merge": { 3802 | "version": "1.0.1", 3803 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3804 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3805 | }, 3806 | "uuid": { 3807 | "version": "8.3.2", 3808 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 3809 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" 3810 | }, 3811 | "v8-compile-cache-lib": { 3812 | "version": "3.0.1", 3813 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 3814 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 3815 | "dev": true 3816 | }, 3817 | "validator": { 3818 | "version": "13.7.0", 3819 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.7.0.tgz", 3820 | "integrity": "sha512-nYXQLCBkpJ8X6ltALua9dRrZDHVYxjJ1wgskNt1lH9fzGjs3tgojGSCBjmEPwkWS1y29+DrizMTW19Pr9uB2nw==" 3821 | }, 3822 | "vary": { 3823 | "version": "1.1.2", 3824 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3825 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3826 | }, 3827 | "wkx": { 3828 | "version": "0.5.0", 3829 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz", 3830 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==", 3831 | "requires": { 3832 | "@types/node": "*" 3833 | } 3834 | }, 3835 | "wrap-ansi": { 3836 | "version": "7.0.0", 3837 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3838 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3839 | "dev": true, 3840 | "requires": { 3841 | "ansi-styles": "^4.0.0", 3842 | "string-width": "^4.1.0", 3843 | "strip-ansi": "^6.0.0" 3844 | } 3845 | }, 3846 | "wrappy": { 3847 | "version": "1.0.2", 3848 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3849 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3850 | "dev": true 3851 | }, 3852 | "xtend": { 3853 | "version": "4.0.2", 3854 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 3855 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" 3856 | }, 3857 | "y18n": { 3858 | "version": "5.0.8", 3859 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3860 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3861 | "dev": true 3862 | }, 3863 | "yallist": { 3864 | "version": "4.0.0", 3865 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3866 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 3867 | }, 3868 | "yargs": { 3869 | "version": "16.2.0", 3870 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3871 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3872 | "dev": true, 3873 | "requires": { 3874 | "cliui": "^7.0.2", 3875 | "escalade": "^3.1.1", 3876 | "get-caller-file": "^2.0.5", 3877 | "require-directory": "^2.1.1", 3878 | "string-width": "^4.2.0", 3879 | "y18n": "^5.0.5", 3880 | "yargs-parser": "^20.2.2" 3881 | } 3882 | }, 3883 | "yargs-parser": { 3884 | "version": "20.2.9", 3885 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 3886 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 3887 | "dev": true 3888 | }, 3889 | "yn": { 3890 | "version": "3.1.1", 3891 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 3892 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 3893 | "dev": true 3894 | } 3895 | } 3896 | } 3897 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "restaurant-api", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "dev": "ts-node-dev --transpile-only --ignore-watch node_modules src/server.ts" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "dependencies": { 13 | "dotenv": "^16.0.1", 14 | "express": "^4.18.1", 15 | "pg": "^8.7.3", 16 | "sequelize": "^6.20.1" 17 | }, 18 | "devDependencies": { 19 | "@types/express": "^4.17.13", 20 | "@types/node": "^17.0.38", 21 | "sequelize-cli": "^6.4.1", 22 | "ts-node-dev": "^2.0.0", 23 | "typescript": "^4.7.2" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /src/controllers/customers-controller.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response } from "express"; 2 | import customerService from "../services/customer-service"; 3 | 4 | export default { 5 | index: async (req: Request, res: Response) => { 6 | try { 7 | const customers = await customerService.findAll() 8 | return res.json(customers) 9 | } catch (error) { 10 | if (error instanceof Error) { 11 | return res.status(400).json({ message: error.message }) 12 | } 13 | } 14 | }, 15 | 16 | async save(req: Request, res: Response) { 17 | const { name, phone } = req.body 18 | try { 19 | const customer = await customerService.save({ name, phone }) 20 | return res.status(201).json(customer) 21 | } catch (error) { 22 | if (error instanceof Error) { 23 | return res.status(400).json({ message: error.message }) 24 | } 25 | } 26 | }, 27 | 28 | async update(req: Request, res: Response) { 29 | const { id } = req.params 30 | const { name, phone } = req.body 31 | try { 32 | await customerService.updateById(id, { name, phone }) 33 | return res.status(204).send() 34 | } catch (error) { 35 | if (error instanceof Error) { 36 | return res.status(400).json({ message: error.message }) 37 | } 38 | } 39 | }, 40 | 41 | async delete(req: Request, res: Response) { 42 | const { id } = req.params 43 | try { 44 | await customerService.deleteById(id) 45 | return res.status(204).send() 46 | } catch (error) { 47 | if (error instanceof Error) { 48 | return res.status(400).json({ message: error.message }) 49 | } 50 | } 51 | }, 52 | 53 | async averageReviews(req: Request, res: Response) { 54 | const { id } = req.params 55 | try { 56 | const customer = await customerService.getAverageReviews(id) 57 | return res.json(customer) 58 | } catch (error) { 59 | if (error instanceof Error) { 60 | return res.status(400).json({ message: error.message }) 61 | } 62 | } 63 | } 64 | } -------------------------------------------------------------------------------- /src/controllers/restaurants-controller.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response } from "express"; 2 | import restaurantService from "../services/restaurant-service"; 3 | import reviewService from "../services/review-service"; 4 | 5 | export default { 6 | async index(req: Request, res: Response) { 7 | try { 8 | const restaurants = await restaurantService.findAll() 9 | return res.json(restaurants) 10 | } catch (error) { 11 | if (error instanceof Error) { 12 | return res.status(400).json({ message: error.message }) 13 | } 14 | } 15 | }, 16 | 17 | async save(req: Request, res: Response) { 18 | const { name, description, phone, address } = req.body 19 | try { 20 | const restaurant = await restaurantService.save({ 21 | name, 22 | description, 23 | phone, 24 | address 25 | }) 26 | return res.status(201).json(restaurant) 27 | } catch (error) { 28 | if (error instanceof Error) { 29 | return res.status(400).json({ message: error.message }) 30 | } 31 | } 32 | }, 33 | 34 | async update(req: Request, res: Response) { 35 | const { id } = req.params 36 | const { name, description, phone, address } = req.body 37 | try { 38 | await restaurantService.updateById(id, { name, description, phone, address }) 39 | return res.status(204).send() 40 | } catch (error) { 41 | if (error instanceof Error) { 42 | return res.status(400).json({ message: error.message }) 43 | } 44 | } 45 | }, 46 | 47 | async delete(req: Request, res: Response) { 48 | const { id } = req.params 49 | try { 50 | await restaurantService.deleteById(id) 51 | return res.status(204).send() 52 | } catch (error) { 53 | if (error instanceof Error) { 54 | return res.status(400).json({ message: error.message }) 55 | } 56 | } 57 | }, 58 | 59 | async averageReviews(req: Request, res: Response) { 60 | const { id } = req.params 61 | try { 62 | const restaurant = await restaurantService.getAverageReviews(id) 63 | return res.json(restaurant) 64 | } catch (error) { 65 | if (error instanceof Error) { 66 | return res.status(400).json({ message: error.message }) 67 | } 68 | } 69 | }, 70 | 71 | async addReview(req: Request, res: Response) { 72 | const restaurantId = Number(req.params.id) 73 | const { customerId, stars, comment } = req.body 74 | try { 75 | const review = await reviewService.save({ restaurantId, customerId, stars, comment }) 76 | return res.status(201).json(review) 77 | } catch (error) { 78 | if (error instanceof Error) { 79 | return res.status(400).json({ message: error.message }) 80 | } 81 | } 82 | }, 83 | 84 | async updateReview(req: Request, res: Response) { 85 | const restaurantId = Number(req.params.id) 86 | const { customerId, stars, comment } = req.body 87 | try { 88 | await reviewService.update({ restaurantId, customerId, stars, comment }) 89 | return res.status(204).send() 90 | } catch (error) { 91 | if (error instanceof Error) { 92 | return res.status(400).json({ message: error.message }) 93 | } 94 | } 95 | }, 96 | 97 | async topFive(req: Request, res: Response) { 98 | try { 99 | const topFive = await restaurantService.getTopFive() 100 | return res.json(topFive) 101 | } catch (error) { 102 | if (error instanceof Error) { 103 | return res.status(400).json({ message: error.message }) 104 | } 105 | } 106 | } 107 | } -------------------------------------------------------------------------------- /src/database/connect.ts: -------------------------------------------------------------------------------- 1 | import { Sequelize } from "sequelize" 2 | 3 | export function connect() { 4 | const databaseUrl = process.env.DATABASE_URL 5 | 6 | if (!databaseUrl) throw new Error('Invalid DATABASE_URL') 7 | 8 | const sequelize = new Sequelize(databaseUrl, { 9 | define: { 10 | underscored: true 11 | } 12 | }) 13 | 14 | return sequelize 15 | } -------------------------------------------------------------------------------- /src/database/index.ts: -------------------------------------------------------------------------------- 1 | import { connect } from "./connect"; 2 | import customer from "./models/customer"; 3 | import restaurant from "./models/restaurant"; 4 | import review from "./models/review"; 5 | 6 | const sequelize = connect() 7 | 8 | const Customer = customer(sequelize) 9 | const Restaurant = restaurant(sequelize) 10 | const Review = review(sequelize) 11 | 12 | Customer.hasMany(Review) 13 | 14 | Restaurant.hasMany(Review) 15 | 16 | Review.belongsTo(Customer) 17 | Review.belongsTo(Restaurant) 18 | 19 | export { 20 | sequelize, 21 | Customer, 22 | Restaurant, 23 | Review 24 | } -------------------------------------------------------------------------------- /src/database/migrations/20220601233650-create-customers-table.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | module.exports = { 4 | async up (queryInterface, Sequelize) { 5 | await queryInterface.createTable('customers', { 6 | id: { 7 | type: Sequelize.INTEGER, 8 | allowNull: false, 9 | primaryKey: true, 10 | autoIncrement: true 11 | }, 12 | name: { 13 | type: Sequelize.STRING, 14 | allowNull: false 15 | }, 16 | phone: { 17 | type: Sequelize.STRING, 18 | allowNull: false 19 | }, 20 | created_at: { 21 | type: Sequelize.DATE, 22 | allowNull: false 23 | }, 24 | updated_at: { 25 | type: Sequelize.DATE, 26 | allowNull: false 27 | }, 28 | }) 29 | }, 30 | 31 | async down (queryInterface, Sequelize) { 32 | await queryInterface.dropTable('customers') 33 | } 34 | }; 35 | -------------------------------------------------------------------------------- /src/database/migrations/20220601233657-create-restaurants-table.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | module.exports = { 4 | async up (queryInterface, Sequelize) { 5 | await queryInterface.createTable('restaurants', { 6 | id: { 7 | type: Sequelize.INTEGER, 8 | allowNull: false, 9 | primaryKey: true, 10 | autoIncrement: true 11 | }, 12 | name: { 13 | type: Sequelize.STRING, 14 | allowNull: false 15 | }, 16 | description: { 17 | type: Sequelize.STRING, 18 | allowNull: false 19 | }, 20 | phone: { 21 | type: Sequelize.STRING, 22 | allowNull: false 23 | }, 24 | address: { 25 | type: Sequelize.STRING, 26 | allowNull: false 27 | }, 28 | created_at: { 29 | type: Sequelize.DATE, 30 | allowNull: false 31 | }, 32 | updated_at: { 33 | type: Sequelize.DATE, 34 | allowNull: false 35 | }, 36 | }) 37 | }, 38 | 39 | async down (queryInterface, Sequelize) { 40 | await queryInterface.dropTable('restaurants') 41 | } 42 | }; 43 | -------------------------------------------------------------------------------- /src/database/migrations/20220601233703-create-reviews-table.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | module.exports = { 4 | async up (queryInterface, Sequelize) { 5 | await queryInterface.createTable('reviews', { 6 | customer_id: { 7 | type: Sequelize.INTEGER, 8 | allowNull: false, 9 | primaryKey: true, 10 | references: { 11 | model: 'customers', 12 | key: 'id' 13 | }, 14 | onUpdate: 'CASCADE', 15 | onDelete: 'CASCADE' 16 | }, 17 | restaurant_id: { 18 | type: Sequelize.INTEGER, 19 | allowNull: false, 20 | primaryKey: true, 21 | references: { 22 | model: 'restaurants', 23 | key: 'id' 24 | }, 25 | onUpdate: 'CASCADE', 26 | onDelete: 'CASCADE' 27 | }, 28 | stars: { 29 | type: Sequelize.INTEGER, 30 | allowNull: false 31 | }, 32 | comment: { 33 | type: Sequelize.STRING 34 | }, 35 | created_at: { 36 | type: Sequelize.DATE, 37 | allowNull: false 38 | }, 39 | updated_at: { 40 | type: Sequelize.DATE, 41 | allowNull: false 42 | }, 43 | }) 44 | }, 45 | 46 | async down (queryInterface, Sequelize) { 47 | await queryInterface.dropTable('reviews') 48 | } 49 | }; 50 | -------------------------------------------------------------------------------- /src/database/models/customer.ts: -------------------------------------------------------------------------------- 1 | import { Sequelize, DataTypes, Optional, Model } from "sequelize" 2 | import { ReviewInstance } from "./review" 3 | 4 | export interface CustomerAttributes { 5 | id: number 6 | name: string 7 | phone: string 8 | } 9 | 10 | export interface CustomerInput extends Optional { } 11 | 12 | export interface CustomerInstance extends Model, CustomerAttributes { 13 | reviews?: ReviewInstance[] 14 | } 15 | 16 | export default function (sequelize: Sequelize) { 17 | const Customer = sequelize.define('customers', { 18 | id: { 19 | type: DataTypes.INTEGER, 20 | allowNull: false, 21 | primaryKey: true, 22 | autoIncrement: true 23 | }, 24 | name: { 25 | type: DataTypes.STRING, 26 | allowNull: false 27 | }, 28 | phone: { 29 | type: DataTypes.STRING, 30 | allowNull: false 31 | } 32 | }) 33 | 34 | return Customer 35 | } -------------------------------------------------------------------------------- /src/database/models/restaurant.ts: -------------------------------------------------------------------------------- 1 | import { DataTypes, Sequelize, Model, Optional } from "sequelize"; 2 | import { ReviewInstance } from "./review"; 3 | 4 | export interface RestaurantAttributes { 5 | id: number 6 | name: string 7 | description: string 8 | phone: string 9 | address: string 10 | } 11 | 12 | export interface RestaurantInput extends Optional { } 13 | 14 | export interface RestaurantInstance extends Model, RestaurantAttributes { 15 | reviews?: ReviewInstance[] 16 | } 17 | 18 | export default function (sequelize: Sequelize) { 19 | const Restaurant = sequelize.define('restaurants', { 20 | id: { 21 | type: DataTypes.INTEGER, 22 | allowNull: false, 23 | primaryKey: true, 24 | autoIncrement: true 25 | }, 26 | name: { 27 | type: DataTypes.STRING, 28 | allowNull: false 29 | }, 30 | description: { 31 | type: DataTypes.STRING, 32 | allowNull: false 33 | }, 34 | phone: { 35 | type: DataTypes.STRING, 36 | allowNull: false 37 | }, 38 | address: { 39 | type: DataTypes.STRING, 40 | allowNull: false 41 | }, 42 | }) 43 | 44 | return Restaurant 45 | } -------------------------------------------------------------------------------- /src/database/models/review.ts: -------------------------------------------------------------------------------- 1 | import { DataTypes, Model, Optional, Sequelize } from "sequelize" 2 | 3 | export interface ReviewAttributes { 4 | customerId: number 5 | restaurantId: number 6 | stars: number 7 | comment: string 8 | } 9 | 10 | export interface ReviewInput extends Optional { } 11 | 12 | export interface ReviewInstance extends Model, ReviewAttributes { } 13 | 14 | export default function (sequelize: Sequelize) { 15 | const Review = sequelize.define('reviews', { 16 | customerId: { 17 | type: DataTypes.INTEGER, 18 | allowNull: false, 19 | primaryKey: true, 20 | references: { 21 | model: 'customers', 22 | key: 'id' 23 | }, 24 | onUpdate: 'CASCADE', 25 | onDelete: 'CASCADE' 26 | }, 27 | restaurantId: { 28 | type: DataTypes.INTEGER, 29 | allowNull: false, 30 | primaryKey: true, 31 | references: { 32 | model: 'restaurants', 33 | key: 'id' 34 | }, 35 | onUpdate: 'CASCADE', 36 | onDelete: 'CASCADE' 37 | }, 38 | stars: { 39 | type: DataTypes.INTEGER, 40 | allowNull: false, 41 | validate: { 42 | isIn: [[0, 1, 2, 3, 4, 5]] 43 | } 44 | }, 45 | comment: { 46 | type: DataTypes.STRING 47 | }, 48 | }) 49 | 50 | return Review 51 | } -------------------------------------------------------------------------------- /src/database/seeders/20220602004742-seed-customers-table.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const { Op } = require("sequelize"); 4 | 5 | module.exports = { 6 | async up(queryInterface, Sequelize) { 7 | await queryInterface.bulkInsert('customers', [ 8 | { name: 'Isaac Pontes', phone: '1234', created_at: new Date(), updated_at: new Date() }, 9 | { name: 'Juliana Conde', phone: '1234', created_at: new Date(), updated_at: new Date() }, 10 | { name: 'Lucas Queiroga', phone: '1234', created_at: new Date(), updated_at: new Date() } 11 | ]) 12 | }, 13 | 14 | async down(queryInterface, Sequelize) { 15 | await queryInterface.bulkDelete('customers', null, { 16 | where: { 17 | [Op.or]: [{ name: 'Isaac Pontes' }, { name: 'Juliana Conde' }, { name: 'Lucas Queiroga' }] 18 | } 19 | }) 20 | } 21 | }; 22 | -------------------------------------------------------------------------------- /src/routes.ts: -------------------------------------------------------------------------------- 1 | import express from "express" 2 | import customersController from "./controllers/customers-controller" 3 | import restaurantsController from "./controllers/restaurants-controller" 4 | 5 | const router = express.Router() 6 | 7 | router.get('/customers', customersController.index) 8 | router.get('/customers/:id/reviews', customersController.averageReviews) 9 | router.post('/customers', customersController.save) 10 | router.put('/customers/:id', customersController.update) 11 | router.delete('/customers/:id', customersController.delete) 12 | 13 | router.get('/restaurants', restaurantsController.index) 14 | router.get('/restaurants/top-five', restaurantsController.topFive) 15 | router.get('/restaurants/:id/reviews', restaurantsController.averageReviews) 16 | router.post('/restaurants', restaurantsController.save) 17 | router.post('/restaurants/:id/reviews', restaurantsController.addReview) 18 | router.put('/restaurants/:id', restaurantsController.update) 19 | router.put('/restaurants/:id/reviews', restaurantsController.updateReview) 20 | router.delete('/restaurants/:id', restaurantsController.delete) 21 | 22 | export { router } -------------------------------------------------------------------------------- /src/server.ts: -------------------------------------------------------------------------------- 1 | import dotenv from "dotenv" 2 | dotenv.config() 3 | 4 | import express from "express" 5 | import { router } from "./routes" 6 | 7 | const app = express() 8 | 9 | app.use(express.json()) 10 | 11 | app.use(router) 12 | 13 | const PORT = process.env.PORT || 3000 14 | 15 | app.listen(PORT, () => { 16 | console.log('Server started!') 17 | }) -------------------------------------------------------------------------------- /src/services/customer-service.ts: -------------------------------------------------------------------------------- 1 | import { Customer } from "../database" 2 | import { CustomerInput } from "../database/models/customer" 3 | 4 | export default { 5 | async findAll() { 6 | const customers = await Customer.findAll() 7 | return customers 8 | }, 9 | 10 | async save(input: CustomerInput) { 11 | const customer = await Customer.create(input) 12 | return customer 13 | }, 14 | 15 | async updateById(id: string | number, input: CustomerInput) { 16 | await Customer.update(input, { 17 | where: { id } 18 | }) 19 | }, 20 | 21 | async deleteById(id: string | number) { 22 | await Customer.destroy({ 23 | where: { id } 24 | }) 25 | }, 26 | 27 | async getAverageReviews(id: string | number) { 28 | const customer = await Customer.findByPk(id, { 29 | attributes: ['id', 'name'], 30 | include: { 31 | association: 'reviews', 32 | attributes: [ 33 | ['restaurant_id', 'restaurantId'], 34 | 'stars', 35 | 'comment' 36 | ] 37 | } 38 | }) 39 | 40 | if (customer === null) return null 41 | 42 | const averageStarsGiven = customer.reviews 43 | ? customer.reviews.reduce((acum, review) => review.stars + acum, 0) / customer.reviews.length 44 | : 0 45 | 46 | return { 47 | customerId: customer.id, 48 | customerName: customer.name, 49 | averageStarsGiven, 50 | reviews: customer.reviews 51 | } 52 | } 53 | } -------------------------------------------------------------------------------- /src/services/restaurant-service.ts: -------------------------------------------------------------------------------- 1 | import { Restaurant } from "../database" 2 | import { RestaurantInput, RestaurantInstance } from "../database/models/restaurant" 3 | 4 | 5 | export default { 6 | async findAll() { 7 | const restaurants = await Restaurant.findAll() 8 | return restaurants 9 | }, 10 | 11 | async save(input: RestaurantInput) { 12 | const restaurant = await Restaurant.create(input) 13 | return restaurant 14 | }, 15 | 16 | async updateById(id: string | number, input: RestaurantInput) { 17 | await Restaurant.update(input, { 18 | where: { id } 19 | }) 20 | }, 21 | 22 | async deleteById(id: string | number) { 23 | await Restaurant.destroy({ 24 | where: { id } 25 | }) 26 | }, 27 | 28 | async getAverageReviews(id: string | number) { 29 | const restaurant = await Restaurant.findByPk(id, { 30 | attributes: ['id', 'name'], 31 | include: { 32 | association: 'reviews', 33 | attributes: [ 34 | ['customer_id', 'customerId'], 35 | 'stars', 36 | 'comment' 37 | ] 38 | } 39 | }) 40 | 41 | if (restaurant === null) return null 42 | 43 | const averageStarsReceived = restaurant.reviews 44 | ? restaurant.reviews.reduce((acum, review) => review.stars + acum, 0) / restaurant.reviews.length 45 | : 0 46 | 47 | return { 48 | restaurantId: restaurant.id, 49 | averageStarsReceived, 50 | reviews: restaurant.reviews 51 | } 52 | }, 53 | 54 | async getTopFive() { 55 | const restaurants = await Restaurant.findAll({ 56 | attributes: ['id', 'name'], 57 | include: { 58 | association: 'reviews', 59 | attributes: [ 60 | 'stars' 61 | ] 62 | } 63 | }) 64 | 65 | const topFive = restaurants.map(restaurant => { 66 | const averageReviews = restaurant.reviews 67 | ? restaurant.reviews.reduce((accum, review) => review.stars + accum, 0) / restaurant.reviews.length 68 | : 0 69 | 70 | return { 71 | ...restaurant.get(), 72 | averageReviews 73 | } 74 | }) 75 | .sort((a, b) => b.averageReviews - a.averageReviews) 76 | .slice(0, 5) 77 | 78 | return topFive 79 | } 80 | } -------------------------------------------------------------------------------- /src/services/review-service.ts: -------------------------------------------------------------------------------- 1 | import { Review } from "../database"; 2 | import { ReviewInput } from "../database/models/review"; 3 | 4 | export default { 5 | async save(input: ReviewInput) { 6 | const review = await Review.create(input) 7 | return review 8 | }, 9 | 10 | async update(input: ReviewInput) { 11 | await Review.update(input, { 12 | where: { 13 | customerId: input.customerId, 14 | restaurantId: input.restaurantId 15 | } 16 | }) 17 | } 18 | } -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Visit https://aka.ms/tsconfig to read more about this file */ 4 | 5 | /* Projects */ 6 | // "incremental": true, /* Save .tsbuildinfo files to allow for incremental compilation of projects. */ 7 | // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ 8 | // "tsBuildInfoFile": "./.tsbuildinfo", /* Specify the path to .tsbuildinfo incremental compilation file. */ 9 | // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects. */ 10 | // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ 11 | // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ 12 | 13 | /* Language and Environment */ 14 | "target": "es2016", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */ 15 | // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */ 16 | // "jsx": "preserve", /* Specify what JSX code is generated. */ 17 | // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ 18 | // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ 19 | // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h'. */ 20 | // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ 21 | // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using 'jsx: react-jsx*'. */ 22 | // "reactNamespace": "", /* Specify the object invoked for 'createElement'. This only applies when targeting 'react' JSX emit. */ 23 | // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ 24 | // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ 25 | // "moduleDetection": "auto", /* Control what method is used to detect module-format JS files. */ 26 | 27 | /* Modules */ 28 | "module": "commonjs", /* Specify what module code is generated. */ 29 | // "rootDir": "./", /* Specify the root folder within your source files. */ 30 | // "moduleResolution": "node", /* Specify how TypeScript looks up a file from a given module specifier. */ 31 | // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ 32 | // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ 33 | // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ 34 | // "typeRoots": [], /* Specify multiple folders that act like './node_modules/@types'. */ 35 | // "types": [], /* Specify type package names to be included without being referenced in a source file. */ 36 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 37 | // "moduleSuffixes": [], /* List of file name suffixes to search when resolving a module. */ 38 | // "resolveJsonModule": true, /* Enable importing .json files. */ 39 | // "noResolve": true, /* Disallow 'import's, 'require's or ''s from expanding the number of files TypeScript should add to a project. */ 40 | 41 | /* JavaScript Support */ 42 | // "allowJs": true, /* Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files. */ 43 | // "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */ 44 | // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'. */ 45 | 46 | /* Emit */ 47 | // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ 48 | // "declarationMap": true, /* Create sourcemaps for d.ts files. */ 49 | // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ 50 | // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ 51 | // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If 'declaration' is true, also designates a file that bundles all .d.ts output. */ 52 | // "outDir": "./", /* Specify an output folder for all emitted files. */ 53 | // "removeComments": true, /* Disable emitting comments. */ 54 | // "noEmit": true, /* Disable emitting files from a compilation. */ 55 | // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ 56 | // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types. */ 57 | // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ 58 | // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ 59 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 60 | // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ 61 | // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ 62 | // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ 63 | // "newLine": "crlf", /* Set the newline character for emitting files. */ 64 | // "stripInternal": true, /* Disable emitting declarations that have '@internal' in their JSDoc comments. */ 65 | // "noEmitHelpers": true, /* Disable generating custom helper functions like '__extends' in compiled output. */ 66 | // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ 67 | // "preserveConstEnums": true, /* Disable erasing 'const enum' declarations in generated code. */ 68 | // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ 69 | // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ 70 | 71 | /* Interop Constraints */ 72 | // "isolatedModules": true, /* Ensure that each file can be safely transpiled without relying on other imports. */ 73 | // "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */ 74 | "esModuleInterop": true, /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */ 75 | // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ 76 | "forceConsistentCasingInFileNames": true, /* Ensure that casing is correct in imports. */ 77 | 78 | /* Type Checking */ 79 | "strict": true, /* Enable all strict type-checking options. */ 80 | // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied 'any' type. */ 81 | // "strictNullChecks": true, /* When type checking, take into account 'null' and 'undefined'. */ 82 | // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ 83 | // "strictBindCallApply": true, /* Check that the arguments for 'bind', 'call', and 'apply' methods match the original function. */ 84 | // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ 85 | // "noImplicitThis": true, /* Enable error reporting when 'this' is given the type 'any'. */ 86 | // "useUnknownInCatchVariables": true, /* Default catch clause variables as 'unknown' instead of 'any'. */ 87 | // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ 88 | // "noUnusedLocals": true, /* Enable error reporting when local variables aren't read. */ 89 | // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read. */ 90 | // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ 91 | // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ 92 | // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ 93 | // "noUncheckedIndexedAccess": true, /* Add 'undefined' to a type when accessed using an index. */ 94 | // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ 95 | // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type. */ 96 | // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ 97 | // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ 98 | 99 | /* Completeness */ 100 | // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ 101 | "skipLibCheck": true /* Skip type checking all .d.ts files. */ 102 | } 103 | } 104 | --------------------------------------------------------------------------------