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

26 |

27 |

28 |

29 |

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