├── .DS_Store ├── .gitignore ├── Procfile ├── README.md ├── app.js ├── controllers ├── category-controller.js ├── image-controller.js ├── order-controller.js ├── product-controller.js └── user-controller.js ├── database └── db_version.sql ├── middleware └── login.js ├── mysql.js ├── package.json ├── routes ├── category-route.js ├── image-route.js ├── order-route.js ├── product-route.js └── user-route.js ├── server.js ├── test ├── category.http ├── order.http ├── product.http └── user.http └── yarn.lock /.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Maransatto/rest-api-node-js/c475c0bd56c898fd231abc13dbb45ac8e88fc49d/.DS_Store -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | .vscode 3 | uploads/* 4 | *session.sql 5 | *.p12 6 | qrcodes/* 7 | nodemon.json -------------------------------------------------------------------------------- /Procfile: -------------------------------------------------------------------------------- 1 | web: node server.js -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Bem Vindo 2 | 3 | ## Agradecimentos 4 | 5 | Gostaria de te agradecer por chegar até aqui. Espero que você possa adquirir um bom conhecimento e compartilhar com outros. 6 | 7 | Este trabalho é o resultado de uma série de vídeo aulas **gratuitas** que tenho disponibilizadas no meu canal do youtube. 8 | 9 | Já que está aqui, aproveite e se inscreva, e apoie este trabalho que eu faço com tanto zelo. 10 | 11 | [CLIQUE AQUI PARA VISITAR A PLAYLIST](https://www.youtube.com/watch?v=hAAj27hgPFg&list=PLWgD0gfm500EMEDPyb3Orb28i7HK5_DkR&index=2&t=0s) 12 | -------------------------------------------------------------------------------- /app.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const app = express(); 3 | const morgan = require('morgan'); 4 | const bodyParser = require('body-parser'); 5 | 6 | const productRoute = require('./routes/product-route'); 7 | const categoryRoute = require('./routes/category-route'); 8 | const orderRoute = require('./routes/order-route'); 9 | const userRoute = require('./routes/user-route'); 10 | const imageRoute = require('./routes/image-route'); 11 | 12 | app.use(morgan('dev')); 13 | app.use('/uploads', express.static('uploads')); 14 | app.use(bodyParser.urlencoded({ extended: false })); // apenas dados simples 15 | app.use(bodyParser.json()); // json de entrada no body 16 | 17 | app.use((req, res, next) => { 18 | res.header('Access-Control-Allow-Origin', '*'); 19 | res.header( 20 | 'Access-Control-Allow-Header', 21 | 'Origin, X-Requested-With, Content-Type, Accept, Authorization' 22 | ); 23 | 24 | if (req.method === 'OPTIONS') { 25 | res.header('Access-Control-Allow-Methods', 'PUT, POST, PATCH, DELETE, GET'); 26 | return res.status(200).send({}); 27 | } 28 | next(); 29 | }); 30 | 31 | app.use('/products', productRoute); 32 | app.use('/categories', categoryRoute); 33 | app.use('/orders', orderRoute); 34 | app.use('/users', userRoute); 35 | app.use('/images', imageRoute); 36 | 37 | app.use((req, res, next) => { 38 | const erro = new Error('Não encontrado'); 39 | erro.status = 404; 40 | next(erro); 41 | }); 42 | 43 | app.use((error, req, res, next) => { 44 | res.status(error.status || 500); 45 | return res.send({ 46 | erro: { 47 | mensagem: error.message 48 | } 49 | }); 50 | }); 51 | 52 | module.exports = app; -------------------------------------------------------------------------------- /controllers/category-controller.js: -------------------------------------------------------------------------------- 1 | const mysql = require('../mysql'); 2 | 3 | exports.getCategories = async (req, res, next) => { 4 | try { 5 | const result = await mysql.execute("SELECT * FROM categories;") 6 | const response = { 7 | length: result.length, 8 | categories: result.map(category => { 9 | return { 10 | categoryId: category.categoryId, 11 | name: category.name 12 | } 13 | }) 14 | } 15 | return res.status(200).send(response); 16 | } catch (error) { 17 | return res.status(500).send({ error: error }); 18 | } 19 | }; 20 | 21 | exports.postCategory = async (req, res, next) => { 22 | try { 23 | const query = 'INSERT INTO categories (name) VALUES (?)'; 24 | const result = await mysql.execute(query, [req.body.name]); 25 | 26 | const response = { 27 | message: 'Categoria inserida com sucesso', 28 | createdCategory: { 29 | categoryId: result.insertId, 30 | name: req.body.name, 31 | request: { 32 | type: 'GET', 33 | description: 'Retorna todas as categorias', 34 | url: process.env.URL_API + 'categories' 35 | } 36 | } 37 | } 38 | return res.status(201).send(response); 39 | } catch (error) { 40 | return res.status(500).send({ error: error }); 41 | } 42 | }; -------------------------------------------------------------------------------- /controllers/image-controller.js: -------------------------------------------------------------------------------- 1 | const mysql = require('../mysql'); 2 | 3 | exports.deleteImage = async (req, res, next) => { 4 | try { 5 | const query = `DELETE FROM productImages WHERE imageId = ?`; 6 | await mysql.execute(query, [req.params.imageId]); 7 | 8 | const response = { 9 | message: 'Imagem removida com sucesso', 10 | request: { 11 | type: 'POST', 12 | description: 'Insere um produto', 13 | url: process.env.URL_API + 'products/' + req.body.productId + '/image', 14 | body: { 15 | productId: 'Number', 16 | path: 'File' 17 | } 18 | } 19 | } 20 | return res.status(202).send(response); 21 | 22 | } catch (error) { 23 | console.error(error) 24 | return res.status(500).send({ error: error }); 25 | } 26 | }; -------------------------------------------------------------------------------- /controllers/order-controller.js: -------------------------------------------------------------------------------- 1 | const mysql = require('../mysql'); 2 | const fs = require('fs'); 3 | const https = require('https'); 4 | const axios = require('axios'); 5 | const randexp = require('randexp'); 6 | 7 | exports.getOrders = async (req, res, next) => { 8 | try { 9 | const query = `SELECT orders.orderId, 10 | orders.quantity, 11 | products.productId, 12 | products.name, 13 | products.price 14 | FROM orders 15 | INNER JOIN products 16 | ON products.productId = orders.productId;` 17 | const result = await mysql.execute(query); 18 | const response = { 19 | orders: result.map(order => { 20 | return { 21 | orderId: order.orderId, 22 | quantity: order.quantity, 23 | product: { 24 | productId: order.productId, 25 | name: order.name, 26 | price: order.price 27 | }, 28 | request: { 29 | type: 'GET', 30 | description: 'Retorna os detalhes de um pedido específico', 31 | url: process.env.URL_API + 'orders/' + order.orderId 32 | } 33 | } 34 | }) 35 | } 36 | return res.status(200).send(response); 37 | 38 | } catch (error) { 39 | return res.status(500).send({ error: error }); 40 | } 41 | }; 42 | 43 | exports.postOrder = async (req, res, next) => { 44 | 45 | 46 | try { 47 | const queryProduct = 'SELECT * FROM products WHERE productId = ?'; 48 | const resultProduct = await mysql.execute(queryProduct, [req.body.productId]); 49 | 50 | if (resultProduct.length == 0) { 51 | return res.status(404).send({ message: 'Produto não encontrado'}); 52 | } 53 | 54 | const queryOrder = 'INSERT INTO orders (productId, quantity) VALUES (?,?)'; 55 | const resultOrder = await mysql.execute(queryOrder, [req.body.productId, req.body.quantity]); 56 | 57 | const response = { 58 | message: 'Pedido inserido com sucesso', 59 | createdOrder: { 60 | orderId: resultOrder.insertId, 61 | productId: req.body.productId, 62 | quantity: req.body.quantity, 63 | request: { 64 | type: 'GET', 65 | description: 'Retorna todos os pedidos', 66 | url: process.env.URL_API + 'orders' 67 | } 68 | } 69 | } 70 | return res.status(201).send(response); 71 | 72 | } catch (error) { 73 | return res.status(500).send({ error: error }); 74 | } 75 | }; 76 | 77 | exports.getOrderDetail = async (req, res, next)=> { 78 | try { 79 | const query = 'SELECT * FROM orders WHERE orderId = ?;'; 80 | const result = await mysql.execute(query, [req.params.orderId]); 81 | 82 | if (result.length == 0) { 83 | return res.status(404).send({ 84 | message: 'Não foi encontrado pedido com este ID' 85 | }) 86 | } 87 | const response = { 88 | order: { 89 | orderId: result[0].orderId, 90 | productId: result[0].productId, 91 | quantity: result[0].quantity, 92 | request: { 93 | type: 'GET', 94 | description: 'Retorna todos os pedidos', 95 | url: process.env.URL_API + 'orders' 96 | } 97 | } 98 | } 99 | return res.status(200).send(response); 100 | 101 | } catch (error) { 102 | return res.status(500).send({ error: error }); 103 | } 104 | }; 105 | 106 | exports.deleteOrder = async (req, res, next) => { 107 | try { 108 | const query = `DELETE FROM orders WHERE orderId = ?`; 109 | await mysql.execute(query, [req.params.orderId]); 110 | 111 | const response = { 112 | message: 'Pedido removido com sucesso', 113 | request: { 114 | type: 'POST', 115 | description: 'Insere um pedido', 116 | url: process.env.URL_API + 'orders', 117 | body: { 118 | productId: 'Number', 119 | quantity: 'Number' 120 | } 121 | } 122 | } 123 | return res.status(202).send(response); 124 | 125 | } catch (error) { 126 | return res.status(500).send({ error: error }); 127 | } 128 | }; 129 | 130 | exports.oAuthGerencianet = async (req, res, next) => { 131 | try { 132 | const cert = fs.readFileSync('prod282386.p12'); 133 | const credentials = process.env.CLIENT_ID + ':' + process.env.CLIENT_SECRET; 134 | const auth = Buffer.from(credentials).toString('base64'); 135 | const agent = https.Agent({ 136 | pfx: cert, 137 | passphrase: '' 138 | }); 139 | const data = JSON.stringify({ "grant_type": "client_credentials" }); 140 | 141 | res.locals.agent = agent 142 | 143 | const config = { 144 | method: 'POST', 145 | url: 'https://api-pix.gerencianet.com.br/oauth/token', 146 | headers: { 147 | Authorization: 'Basic ' + auth, 148 | 'Content-Type': 'application/json' 149 | }, 150 | httpsAgent: agent, 151 | data: data 152 | } 153 | 154 | axios(config) 155 | .then(response => { 156 | res.locals.accessToken = response.data.access_token; 157 | console.log('Auth', response.data); 158 | next(); 159 | }) 160 | .catch(erro => { 161 | console.log(error); 162 | return res.status(500).send({ error: error }); 163 | }) 164 | 165 | } catch (error) { 166 | return res.status(500).send({ error: error }); 167 | } 168 | } 169 | 170 | exports.createPixBilling = async (req, res, next) => { 171 | try { 172 | const data = JSON.stringify({ 173 | "calendario": { "expiracao": 3600 }, 174 | "devedor": { 175 | "cpf": req.body.payee.cpf, 176 | "nome": req.body.payee.name 177 | }, 178 | "valor": { "original": req.body.value }, 179 | "chave": process.env.CHAVE_PIX, 180 | "solicitacaoPagador": req.body.description 181 | }); 182 | 183 | txId = new randexp(/^[a-zA-Z0-9]{26,35}$/).gen(); 184 | 185 | const config = { 186 | method: 'PUT', 187 | url: `https://api-pix.gerencianet.com.br/v2/cob/${txId}`, 188 | headers: { 189 | Authorization: 'Bearer ' + res.locals.accessToken, 190 | 'Content-Type': 'application/json' 191 | }, 192 | httpsAgent: res.locals.agent, 193 | data: data 194 | } 195 | 196 | axios(config) 197 | .then(response => { 198 | res.locals.billing = response.data; 199 | console.log('Billing', response.data); 200 | next(); 201 | }) 202 | .catch(erro => { 203 | console.log(error); 204 | return res.status(500).send({ error: error }); 205 | }) 206 | } catch (error) { 207 | return res.status(500).send({ error: error }); 208 | } 209 | } 210 | 211 | exports.getQrCode = async (req, res, next) => { 212 | try { 213 | const locId = res.locals.billing.loc.id; 214 | const config = { 215 | method: 'GET', 216 | url: `https://api-pix.gerencianet.com.br/v2/loc/${locId}/qrcode`, 217 | headers: { 218 | Authorization: 'Bearer ' + res.locals.accessToken, 219 | 'Content-Type': 'application/json' 220 | }, 221 | httpsAgent: res.locals.agent 222 | } 223 | 224 | axios(config) 225 | .then(response => { 226 | imgQrCode = decodeBase64Image(response.data.imagemQrcode); 227 | fs.writeFileSync(`qrcodes/pix-billing-${locId}.jpg`, imgQrCode.data) 228 | console.log('QrCode', response.data); 229 | next(); 230 | }) 231 | .catch(erro => { 232 | console.log(error); 233 | return res.status(500).send({ error: error }); 234 | }) 235 | } catch (error) { 236 | return res.status(500).send({ error: error }); 237 | } 238 | } 239 | 240 | function decodeBase64Image(dataString) { 241 | var matches = dataString.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/), 242 | response = {}; 243 | if (matches.length !== 3) { 244 | return new Error('Invalid input string'); 245 | } 246 | response.type = matches[1]; 247 | response.data = new Buffer.from(matches[2], 'base64'); 248 | return response; 249 | } -------------------------------------------------------------------------------- /controllers/product-controller.js: -------------------------------------------------------------------------------- 1 | const mysql = require('../mysql'); 2 | 3 | exports.getProducts = async (req, res, next) => { 4 | try { 5 | let name = ''; 6 | if (req.query.name) { 7 | name = req.query.name; 8 | } 9 | 10 | const query = ` 11 | SELECT * 12 | FROM products 13 | WHERE categoryId = ? 14 | AND ( 15 | name LIKE '%${name}%' 16 | ); 17 | `; 18 | const result = await mysql.execute(query, [ 19 | req.query.categoryId 20 | ]) 21 | const response = { 22 | length: result.length, 23 | products: result.map(prod => { 24 | return { 25 | productId: prod.productId, 26 | name: prod.name, 27 | price: prod.price, 28 | productImage: prod.productImage, 29 | request: { 30 | type: 'GET', 31 | description: 'Retorna os detalhes de um produto específico', 32 | url: process.env.URL_API + 'produtos/' + prod.productId 33 | } 34 | } 35 | }) 36 | } 37 | return res.status(200).send(response); 38 | } catch (error) { 39 | return res.status(500).send({ error: error }); 40 | } 41 | }; 42 | 43 | exports.postProduct = async (req, res, next) => { 44 | try { 45 | const query = 'INSERT INTO products (name, price, productImage, categoryId) VALUES (?,?,?,?)'; 46 | const result = await mysql.execute(query, [ 47 | req.body.name, 48 | req.body.price, 49 | req.file.path, 50 | req.body.categoryId, 51 | ]); 52 | 53 | const response = { 54 | message: 'Produto inserido com sucesso', 55 | createdProduct: { 56 | productId: result.insertId, 57 | name: req.body.name, 58 | price: req.body.price, 59 | productImage: req.file.path, 60 | categoryId: req.body.categoryId, 61 | request: { 62 | type: 'GET', 63 | description: 'Retorna todos os produtos', 64 | url: process.env.URL_API + 'produtos' 65 | } 66 | } 67 | } 68 | return res.status(201).send(response); 69 | } catch (error) { 70 | return res.status(500).send({ error: error }); 71 | } 72 | }; 73 | 74 | exports.getProductDetail = async (req, res, next)=> { 75 | try { 76 | const query = 'SELECT * FROM products WHERE productId = ?;'; 77 | const result = await mysql.execute(query, [req.params.productId]); 78 | 79 | if (result.length == 0) { 80 | return res.status(404).send({ 81 | message: 'Não foi encontrado produto com este ID' 82 | }) 83 | } 84 | const response = { 85 | product: { 86 | productId: result[0].productId, 87 | name: result[0].name, 88 | price: result[0].price, 89 | productImage: result[0].productImage, 90 | request: { 91 | type: 'GET', 92 | description: 'Retorna todos os produtos', 93 | url: process.env.URL_API + 'produtos' 94 | } 95 | } 96 | } 97 | return res.status(200).send(response); 98 | } catch (error) { 99 | return res.status(500).send({ error: error }); 100 | } 101 | }; 102 | 103 | exports.updateProduct = async (req, res, next) => { 104 | 105 | try { 106 | const query = ` UPDATE products 107 | SET name = ?, 108 | price = ? 109 | WHERE productId = ?`; 110 | await mysql.execute(query, [ 111 | req.body.name, 112 | req.body.price, 113 | req.params.productId 114 | ]); 115 | const response = { 116 | message: 'Produto atualizado com sucesso', 117 | upatedProduct: { 118 | productId: req.params.productId, 119 | name: req.body.name, 120 | price: req.body.price, 121 | request: { 122 | type: 'GET', 123 | description: 'Retorna os detalhes de um produto específico', 124 | url: process.env.URL_API + 'produtos/' + req.params.productId 125 | } 126 | } 127 | } 128 | return res.status(202).send(response); 129 | } catch (error) { 130 | return res.status(500).send({ error: error }); 131 | } 132 | }; 133 | 134 | exports.deleteProduct = async (req, res, next) => { 135 | try { 136 | const query = `DELETE FROM products WHERE productId = ?`; 137 | await mysql.execute(query, [req.params.productId]); 138 | 139 | const response = { 140 | message: 'Produto removido com sucesso', 141 | request: { 142 | type: 'POST', 143 | description: 'Insere um produto', 144 | url: process.env.URL_API + 'produtos', 145 | body: { 146 | name: 'String', 147 | price: 'Number' 148 | } 149 | } 150 | } 151 | return res.status(202).send(response); 152 | 153 | } catch (error) { 154 | return res.status(500).send({ error: error }); 155 | } 156 | }; 157 | 158 | exports.postImage = async (req, res, next) => { 159 | try { 160 | const query = 'INSERT INTO productImages (productId, path) VALUES (?,?)'; 161 | const result = await mysql.execute(query, [ 162 | req.params.productId, 163 | req.file.path 164 | ]); 165 | 166 | const response = { 167 | message: 'Imagem inserida com sucesso', 168 | createdImage: { 169 | productId: parseInt(req.params.productId), 170 | imageId: result.insertId, 171 | path: req.file.path, 172 | request: { 173 | type: 'GET', 174 | description: 'Retorna todos as imagens', 175 | url: process.env.URL_API + 'produtos/' + req.params.productId + '/imagens' 176 | } 177 | } 178 | } 179 | return res.status(201).send(response); 180 | } catch (error) { 181 | return res.status(500).send({ error: error }); 182 | } 183 | }; 184 | 185 | exports.getImages = async (req, res, next) => { 186 | try { 187 | const query = "SELECT * FROM productImages WHERE productId = ?;" 188 | const result = await mysql.execute(query, [req.params.productId]) 189 | const response = { 190 | length: result.length, 191 | images: result.map(img => { 192 | return { 193 | productId: parseInt(req.params.productId), 194 | imageId: img.imageId, 195 | path: process.env.URL_API + img.path 196 | } 197 | }) 198 | } 199 | return res.status(200).send(response); 200 | } catch (error) { 201 | return res.status(500).send({ error: error }); 202 | } 203 | }; -------------------------------------------------------------------------------- /controllers/user-controller.js: -------------------------------------------------------------------------------- 1 | const mysql = require('../mysql'); 2 | const bcrypt = require('bcrypt'); 3 | const jwt = require('jsonwebtoken'); 4 | 5 | exports.createUser = async (req, res, next) => { 6 | 7 | try { 8 | // var query = `SELECT * FROM users WHERE email = ?`; 9 | // var result = await mysql.execute(query, [req.body.email]); 10 | 11 | // if (result.length > 0) { 12 | // return res.status(409).send({ message: 'Usuário já cadastrado' }) 13 | // } 14 | 15 | // const hash = await bcrypt.hashSync(req.body.password, 10); 16 | 17 | const users = req.body.users.map(user => [ 18 | user.email, 19 | bcrypt.hashSync(user.password, 10) 20 | ]) 21 | 22 | query = 'INSERT INTO users (email, password) VALUES ?'; 23 | const results = await mysql.execute(query, [ users ]); 24 | 25 | const response = { 26 | message: 'Usuário criado com sucesso', 27 | createdUsers: req.body.users.map(user => { return { email: user.email } }) 28 | } 29 | return res.status(201).send(response); 30 | 31 | } catch (error) { 32 | return res.status(500).send({ error: error }); 33 | } 34 | }; 35 | 36 | exports.Login = async (req, res, next) => { 37 | 38 | try { 39 | const query = `SELECT * FROM users WHERE email = ?`; 40 | var results = await mysql.execute(query, [req.body.email]); 41 | 42 | if (results.length < 1) { 43 | return res.status(401).send({ message: 'Falha na autenticação' }) 44 | } 45 | 46 | if (await bcrypt.compareSync(req.body.password, results[0].password)) { 47 | const token = jwt.sign({ 48 | userId: results[0].userId, 49 | email: results[0].email 50 | }, 51 | process.env.JWT_KEY, 52 | { 53 | expiresIn: "1h" 54 | }); 55 | return res.status(200).send({ 56 | message: 'Autenticado com sucesso', 57 | token: token 58 | }); 59 | } 60 | return res.status(401).send({ message: 'Falha na autenticação' }) 61 | 62 | } catch (error) { 63 | return res.status(500).send({ message: 'Falha na autenticação' }); 64 | } 65 | }; -------------------------------------------------------------------------------- /database/db_version.sql: -------------------------------------------------------------------------------- 1 | -- 16/07/2020 2 | CREATE TABLE IF NOT EXISTS productImages ( 3 | imageId INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 4 | productId INT, 5 | path VARCHAR(255), 6 | FOREIGN KEY (productId) REFERENCES products (productId) 7 | ); 8 | 9 | -- refactoring pra inglês 10 | drop table pedidos; 11 | drop table usuarios; 12 | drop table imagens_produtos; 13 | drop table produtos; 14 | 15 | CREATE TABLE IF NOT EXISTS products ( 16 | productId INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 17 | name VARCHAR(45), 18 | price FLOAT, 19 | productImage VARCHAR(255) 20 | ); 21 | 22 | CREATE TABLE IF NOT EXISTS orders ( 23 | orderId INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 24 | productId INT, 25 | quantity INT, 26 | FOREIGN KEY (productId) REFERENCES products (productId) 27 | ); 28 | 29 | CREATE TABLE IF NOT EXISTS users ( 30 | userId INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 31 | email VARCHAR(100), 32 | password VARCHAR(100) 33 | ); 34 | 35 | CREATE TABLE IF NOT EXISTS productImages ( 36 | imageId INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 37 | productId INT, 38 | path VARCHAR(255), 39 | FOREIGN KEY (productId) REFERENCES products (productId) 40 | ); 41 | 42 | -- 22/08/2020 43 | CREATE TABLE IF NOT EXISTS categories ( 44 | categoryId INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 45 | name VARCHAR(100) 46 | ); 47 | 48 | ALTER TABLE products ADD categoryId INT NULL; 49 | 50 | INSERT INTO categories (name) VALUES ('Material Escolar'); 51 | 52 | UPDATE products SET categoryId = 1; 53 | 54 | ALTER TABLE products MODIFY categoryId INT NOT NULL; 55 | ALTER TABLE products ADD CONSTRAINT fk_product_category 56 | FOREIGN KEY (categoryId) REFERENCES categories(categoryId); 57 | 58 | -------------------------------------------------------------------------------- /middleware/login.js: -------------------------------------------------------------------------------- 1 | const jwt = require('jsonwebtoken'); 2 | 3 | exports.required = (req, res, next) => { 4 | 5 | try { 6 | const token = req.headers.authorization.split(' ')[1]; 7 | const decode = jwt.verify(token, process.env.JWT_KEY); 8 | req.user = decode; 9 | next(); 10 | } catch (error) { 11 | return res.status(401).send({ mensagem: 'Falha na autenticação' }); 12 | } 13 | 14 | } 15 | 16 | exports.optional = (req, res, next) => { 17 | 18 | try { 19 | const token = req.headers.authorization.split(' ')[1]; 20 | const decode = jwt.verify(token, process.env.JWT_KEY); 21 | req.user = decode; 22 | next(); 23 | } catch (error) { 24 | next(); 25 | } 26 | 27 | } -------------------------------------------------------------------------------- /mysql.js: -------------------------------------------------------------------------------- 1 | const mysql = require('mysql'); 2 | 3 | var pool = mysql.createPool({ 4 | "connectionLimit" : 1000, 5 | "user" : process.env.MYSQL_USER, 6 | "password": process.env.MYSQL_PASSWORD, 7 | "database" : process.env.MYSQL_DATABASE, 8 | "host": process.env.MYSQL_HOST, 9 | "port" : process.env.MYSQL_PORT 10 | }); 11 | 12 | exports.execute = (query, params=[]) => { 13 | return new Promise((resolve, reject) => { 14 | pool.query(query, params, (error, result, fields) => { 15 | if (error) { 16 | reject(error); 17 | } else { 18 | resolve(result) 19 | } 20 | }); 21 | }) 22 | } 23 | 24 | exports.pool = pool; -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "rest-api", 3 | "version": "1.0.0", 4 | "description": "Teste de REST API para tutorial do youtube", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "nodemon server.js" 9 | }, 10 | "keywords": [ 11 | "node", 12 | "tutorial", 13 | "youtube" 14 | ], 15 | "author": "Fernando Silva Maransatto", 16 | "license": "ISC", 17 | "dependencies": { 18 | "axios": "^1.7.9", 19 | "bcrypt": "^5.1.1", 20 | "body-parser": "^1.20.3", 21 | "express": "^4.21.2", 22 | "jsonwebtoken": "^9.0.2", 23 | "morgan": "^1.10.0", 24 | "multer": "^1.4.4", 25 | "mysql": "^2.18.1", 26 | "randexp": "^0.5.3" 27 | }, 28 | "devDependencies": { 29 | "nodemon": "^3.1.9" 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /routes/category-route.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const router = express.Router(); 3 | const login = require('../middleware/login'); 4 | 5 | const CategoriesController = require('../controllers/category-controller'); 6 | 7 | router.get('/', CategoriesController.getCategories); 8 | router.post('/', login.required, CategoriesController.postCategory); 9 | 10 | module.exports = router; -------------------------------------------------------------------------------- /routes/image-route.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const router = express.Router(); 3 | const login = require('../middleware/login'); 4 | 5 | const imageController = require('../controllers/image-controller'); 6 | 7 | router.delete('/:imageId', login.required, imageController.deleteImage); 8 | 9 | module.exports = router; -------------------------------------------------------------------------------- /routes/order-route.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const router = express.Router(); 3 | 4 | const orderController = require('../controllers/order-controller'); 5 | 6 | router.get('/', orderController.getOrders); 7 | router.post('/', orderController.postOrder); 8 | router.get('/:orderId', orderController.getOrderDetail); 9 | router.delete('/:orderId', orderController.deleteOrder); 10 | 11 | router.post('/:orderId/pix/billing', orderController.oAuthGerencianet, 12 | orderController.createPixBilling, 13 | orderController.getQrCode) 14 | 15 | module.exports = router; -------------------------------------------------------------------------------- /routes/product-route.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const router = express.Router(); 3 | const multer = require('multer'); 4 | const login = require('../middleware/login'); 5 | 6 | const ProductsController = require('../controllers/product-controller'); 7 | 8 | const storage = multer.diskStorage({ 9 | destination: function (req, file, cb) { 10 | cb(null, './uploads/'); 11 | }, 12 | filename: function(req, file, cb) { 13 | cb(null, new Date().toISOString() + file.originalname); 14 | } 15 | }); 16 | 17 | const fileFilter = (req, file, cb) => { 18 | if (file.mimetype === 'image/jpeg' || file.mimetype === 'image/png') { 19 | cb(null, true); 20 | } else { 21 | cb(null, false); 22 | } 23 | } 24 | 25 | const upload = multer({ 26 | storage: storage, 27 | limits: { 28 | fileSize: 1024 * 1024 * 5 29 | }, 30 | fileFilter: fileFilter 31 | }); 32 | 33 | router.get('/', ProductsController.getProducts); 34 | 35 | router.post( 36 | '/', 37 | login.required, 38 | upload.single('image'), 39 | ProductsController.postProduct 40 | ); 41 | router.get('/:productId', ProductsController.getProductDetail); 42 | router.patch('/:productId', login.required, ProductsController.updateProduct); 43 | router.delete('/:productId', login.required, ProductsController.deleteProduct); 44 | 45 | // imagens 46 | router.post( 47 | '/:productId/image', 48 | login.required, 49 | upload.single('image'), 50 | ProductsController.postImage 51 | ) 52 | router.get( 53 | '/:productId/images', 54 | ProductsController.getImages 55 | ) 56 | 57 | module.exports = router; -------------------------------------------------------------------------------- /routes/user-route.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const router = express.Router(); 3 | 4 | const userController = require('../controllers/user-controller'); 5 | 6 | router.post('/', userController.createUser); 7 | router.post('/login', userController.Login) 8 | 9 | module.exports = router; -------------------------------------------------------------------------------- /server.js: -------------------------------------------------------------------------------- 1 | const http = require('http'); 2 | const app = require('./app'); 3 | const port = process.env.PORT || 3000; 4 | const server = http.createServer(app); 5 | server.listen(port); -------------------------------------------------------------------------------- /test/category.http: -------------------------------------------------------------------------------- 1 | # Busca as categorias 2 | GET http://localhost:3000/categories 3 | Content-Type: application/json 4 | ### 5 | 6 | 7 | # Inclui uma nova categoria 8 | POST http://localhost:3000/categories 9 | Content-Type: application/json 10 | Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOjIsImVtYWlsIjoiZmVybmFuZG8ubWFyYW5zYXR0b0BnbWFpbC5jb20iLCJpYXQiOjE2MjQ5ODk5MzIsImV4cCI6MTYyNDk5MzUzMn0.8yrR4tfNdtR99NwoZUJ6vVRK9d8tk7iWngOxI4A62Lc 11 | 12 | { 13 | "name" : "Roupas" 14 | } 15 | ### 16 | -------------------------------------------------------------------------------- /test/order.http: -------------------------------------------------------------------------------- 1 | # Get orders 2 | GET http://localhost:3000/orders 3 | Content-Type: application/json 4 | ### 5 | 6 | # Post order 7 | POST http://localhost:3000/orders 8 | Content-Type: application/json 9 | 10 | { 11 | "productId": 5, 12 | "quantity": 2 13 | } 14 | ### 15 | 16 | # Get order detail 17 | GET http://localhost:3000/orders/2 18 | Content-Type: application/json 19 | ### 20 | 21 | 22 | # Remove an order 23 | DELETE http://localhost:3000/orders/2 24 | Content-Type: application/json 25 | ### 26 | 27 | -------------------------------------------------------------------------------- /test/product.http: -------------------------------------------------------------------------------- 1 | # Retorna todos os produtos 2 | GET http://localhost:3000/products/?categoryId=1&name=Preta 3 | Content-Type: application/json 4 | ### 5 | 6 | # Retorna detalhes de um produto 7 | GET http://localhost:3000/products/2 8 | Content-Type: application/json 9 | ### 10 | 11 | # Altera um produto 12 | PATCH http://localhost:3000/products/1 13 | Content-Type: application/json 14 | Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJlbWFpbCI6Imx1Y2lhbm9AZ21haWwuY29tIiwiaWF0IjoxNTk1MTAwMzkwLCJleHAiOjE1OTUxMDM5OTB9.9-wb_FgeE-fy6sk3vhwoluYY2LK5wfqHq4Yniv4f76M 15 | 16 | { 17 | "name" : "Caneta Azul Alterada", 18 | "price" : 11.50 19 | } 20 | ### 21 | 22 | # Remove um produto 23 | DELETE http://localhost:3000/products/3 24 | Content-Type: application/json 25 | Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJlbWFpbCI6Imx1Y2lhbm9AZ21haWwuY29tIiwiaWF0IjoxNTk1MTAwMzkwLCJleHAiOjE1OTUxMDM5OTB9.9-wb_FgeE-fy6sk3vhwoluYY2LK5wfqHq4Yniv4f76M 26 | ### 27 | 28 | # Remove um produto 29 | DELETE http://localhost:3000/products/3 30 | Content-Type: application/json 31 | Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJlbWFpbCI6Imx1Y2lhbm9AZ21haWwuY29tIiwiaWF0IjoxNTk1MTAwMzkwLCJleHAiOjE1OTUxMDM5OTB9.9-wb_FgeE-fy6sk3vhwoluYY2LK5wfqHq4Yniv4f76M 32 | ### 33 | 34 | 35 | # Insere uma imagem 36 | POST http://localhost:3000/produtos 37 | Content-Type: multipart/form-data; 38 | 39 | ------- 40 | Content-Disposition: form-data; nome="caneta"; preco="10.99; " 41 | Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZF91c3VhcmlvIjoyMiwiZW1haWwiOiJmZXJuYW5kby5tYXJhbnNhdHRvQGdtYWlsLmNvbSIsImlhdCI6MTU5NDg0Mzg2MiwiZXhwIjoxNTk0ODQ3NDYyfQ.KSSKiAfIfCpBWWA-j_dL40c-t2YY1yk2wKIq8mGfQJU 42 | 43 | < /Users/maransatto/Pictures/curso/caneta-vermelha.jpg 44 | ### 45 | 46 | 47 | -------------------------------------------------------------------------------- /test/user.http: -------------------------------------------------------------------------------- 1 | # Cadastra um Usuário 2 | POST http://localhost:3000/users 3 | Content-Type: application/json 4 | 5 | { 6 | "email" : "fernando.maransatto@gmail.com", 7 | "password" : "maransatto" 8 | } 9 | 10 | ### 11 | 12 | # Faz o login do usuário 13 | POST http://localhost:3000/users/login 14 | Content-Type: application/json 15 | 16 | { 17 | "email" : "fernando.maransatto@gmail.com", 18 | "password" : "maransatto" 19 | } 20 | ### 21 | 22 | -------------------------------------------------------------------------------- /yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | "@mapbox/node-pre-gyp@^1.0.11": 6 | version "1.0.11" 7 | resolved "https://registry.yarnpkg.com/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.11.tgz#417db42b7f5323d79e93b34a6d7a2a12c0df43fa" 8 | integrity sha512-Yhlar6v9WQgUp/He7BdgzOz8lqMQ8sU+jkCq7Wx8Myc5YFJLbEe7lgui/V7G1qB1DJykHSGwreceSaD60Y0PUQ== 9 | dependencies: 10 | detect-libc "^2.0.0" 11 | https-proxy-agent "^5.0.0" 12 | make-dir "^3.1.0" 13 | node-fetch "^2.6.7" 14 | nopt "^5.0.0" 15 | npmlog "^5.0.1" 16 | rimraf "^3.0.2" 17 | semver "^7.3.5" 18 | tar "^6.1.11" 19 | 20 | abbrev@1: 21 | version "1.1.1" 22 | resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" 23 | integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== 24 | 25 | accepts@~1.3.8: 26 | version "1.3.8" 27 | resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.8.tgz#0bf0be125b67014adcb0b0921e62db7bffe16b2e" 28 | integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== 29 | dependencies: 30 | mime-types "~2.1.34" 31 | negotiator "0.6.3" 32 | 33 | agent-base@6: 34 | version "6.0.2" 35 | resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77" 36 | integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== 37 | dependencies: 38 | debug "4" 39 | 40 | ansi-regex@^5.0.1: 41 | version "5.0.1" 42 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" 43 | integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== 44 | 45 | anymatch@~3.1.2: 46 | version "3.1.3" 47 | resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.3.tgz#790c58b19ba1720a84205b57c618d5ad8524973e" 48 | integrity sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw== 49 | dependencies: 50 | normalize-path "^3.0.0" 51 | picomatch "^2.0.4" 52 | 53 | append-field@^1.0.0: 54 | version "1.0.0" 55 | resolved "https://registry.yarnpkg.com/append-field/-/append-field-1.0.0.tgz#1e3440e915f0b1203d23748e78edd7b9b5b43e56" 56 | integrity sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw== 57 | 58 | "aproba@^1.0.3 || ^2.0.0": 59 | version "2.0.0" 60 | resolved "https://registry.yarnpkg.com/aproba/-/aproba-2.0.0.tgz#52520b8ae5b569215b354efc0caa3fe1e45a8adc" 61 | integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== 62 | 63 | are-we-there-yet@^2.0.0: 64 | version "2.0.0" 65 | resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz#372e0e7bd279d8e94c653aaa1f67200884bf3e1c" 66 | integrity sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw== 67 | dependencies: 68 | delegates "^1.0.0" 69 | readable-stream "^3.6.0" 70 | 71 | array-flatten@1.1.1: 72 | version "1.1.1" 73 | resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" 74 | integrity sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg== 75 | 76 | asynckit@^0.4.0: 77 | version "0.4.0" 78 | resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" 79 | integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== 80 | 81 | axios@^1.7.9: 82 | version "1.7.9" 83 | resolved "https://registry.yarnpkg.com/axios/-/axios-1.7.9.tgz#d7d071380c132a24accda1b2cfc1535b79ec650a" 84 | integrity sha512-LhLcE7Hbiryz8oMDdDptSrWowmB4Bl6RCt6sIJKpRB4XtVf0iEgewX3au/pJqm+Py1kCASkb/FFKjxQaLtxJvw== 85 | dependencies: 86 | follow-redirects "^1.15.6" 87 | form-data "^4.0.0" 88 | proxy-from-env "^1.1.0" 89 | 90 | balanced-match@^1.0.0: 91 | version "1.0.2" 92 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" 93 | integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== 94 | 95 | basic-auth@~2.0.1: 96 | version "2.0.1" 97 | resolved "https://registry.yarnpkg.com/basic-auth/-/basic-auth-2.0.1.tgz#b998279bf47ce38344b4f3cf916d4679bbf51e3a" 98 | integrity sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg== 99 | dependencies: 100 | safe-buffer "5.1.2" 101 | 102 | bcrypt@^5.1.1: 103 | version "5.1.1" 104 | resolved "https://registry.yarnpkg.com/bcrypt/-/bcrypt-5.1.1.tgz#0f732c6dcb4e12e5b70a25e326a72965879ba6e2" 105 | integrity sha512-AGBHOG5hPYZ5Xl9KXzU5iKq9516yEmvCKDg3ecP5kX2aB6UqTeXZxk2ELnDgDm6BQSMlLt9rDB4LoSMx0rYwww== 106 | dependencies: 107 | "@mapbox/node-pre-gyp" "^1.0.11" 108 | node-addon-api "^5.0.0" 109 | 110 | bignumber.js@9.0.0: 111 | version "9.0.0" 112 | resolved "https://registry.yarnpkg.com/bignumber.js/-/bignumber.js-9.0.0.tgz#805880f84a329b5eac6e7cb6f8274b6d82bdf075" 113 | integrity sha512-t/OYhhJ2SD+YGBQcjY8GzzDHEk9f3nerxjtfa6tlMXfe7frs/WozhvCNoGvpM0P3bNf3Gq5ZRMlGr5f3r4/N8A== 114 | 115 | binary-extensions@^2.0.0: 116 | version "2.3.0" 117 | resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.3.0.tgz#f6e14a97858d327252200242d4ccfe522c445522" 118 | integrity sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw== 119 | 120 | body-parser@1.20.3, body-parser@^1.20.3: 121 | version "1.20.3" 122 | resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.3.tgz#1953431221c6fb5cd63c4b36d53fab0928e548c6" 123 | integrity sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g== 124 | dependencies: 125 | bytes "3.1.2" 126 | content-type "~1.0.5" 127 | debug "2.6.9" 128 | depd "2.0.0" 129 | destroy "1.2.0" 130 | http-errors "2.0.0" 131 | iconv-lite "0.4.24" 132 | on-finished "2.4.1" 133 | qs "6.13.0" 134 | raw-body "2.5.2" 135 | type-is "~1.6.18" 136 | unpipe "1.0.0" 137 | 138 | brace-expansion@^1.1.7: 139 | version "1.1.11" 140 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" 141 | integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== 142 | dependencies: 143 | balanced-match "^1.0.0" 144 | concat-map "0.0.1" 145 | 146 | braces@~3.0.2: 147 | version "3.0.3" 148 | resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.3.tgz#490332f40919452272d55a8480adc0c441358789" 149 | integrity sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA== 150 | dependencies: 151 | fill-range "^7.1.1" 152 | 153 | buffer-equal-constant-time@1.0.1: 154 | version "1.0.1" 155 | resolved "https://registry.yarnpkg.com/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz#f8e71132f7ffe6e01a5c9697a4c6f3e48d5cc819" 156 | integrity sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA== 157 | 158 | buffer-from@^1.0.0: 159 | version "1.1.2" 160 | resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" 161 | integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== 162 | 163 | busboy@^0.2.11: 164 | version "0.2.14" 165 | resolved "https://registry.yarnpkg.com/busboy/-/busboy-0.2.14.tgz#6c2a622efcf47c57bbbe1e2a9c37ad36c7925453" 166 | integrity sha512-InWFDomvlkEj+xWLBfU3AvnbVYqeTWmQopiW0tWWEy5yehYm2YkGEc59sUmw/4ty5Zj/b0WHGs1LgecuBSBGrg== 167 | dependencies: 168 | dicer "0.2.5" 169 | readable-stream "1.1.x" 170 | 171 | bytes@3.1.2: 172 | version "3.1.2" 173 | resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" 174 | integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== 175 | 176 | call-bind-apply-helpers@^1.0.1: 177 | version "1.0.1" 178 | resolved "https://registry.yarnpkg.com/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.1.tgz#32e5892e6361b29b0b545ba6f7763378daca2840" 179 | integrity sha512-BhYE+WDaywFg2TBWYNXAE+8B1ATnThNBqXHP5nQu0jWJdVvY2hvkpyB3qOmtmDePiS5/BDQ8wASEWGMWRG148g== 180 | dependencies: 181 | es-errors "^1.3.0" 182 | function-bind "^1.1.2" 183 | 184 | call-bound@^1.0.2: 185 | version "1.0.3" 186 | resolved "https://registry.yarnpkg.com/call-bound/-/call-bound-1.0.3.tgz#41cfd032b593e39176a71533ab4f384aa04fd681" 187 | integrity sha512-YTd+6wGlNlPxSuri7Y6X8tY2dmm12UMH66RpKMhiX6rsk5wXXnYgbUcOt8kiS31/AjfoTOvCsE+w8nZQLQnzHA== 188 | dependencies: 189 | call-bind-apply-helpers "^1.0.1" 190 | get-intrinsic "^1.2.6" 191 | 192 | chokidar@^3.5.2: 193 | version "3.6.0" 194 | resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.6.0.tgz#197c6cc669ef2a8dc5e7b4d97ee4e092c3eb0d5b" 195 | integrity sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw== 196 | dependencies: 197 | anymatch "~3.1.2" 198 | braces "~3.0.2" 199 | glob-parent "~5.1.2" 200 | is-binary-path "~2.1.0" 201 | is-glob "~4.0.1" 202 | normalize-path "~3.0.0" 203 | readdirp "~3.6.0" 204 | optionalDependencies: 205 | fsevents "~2.3.2" 206 | 207 | chownr@^2.0.0: 208 | version "2.0.0" 209 | resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" 210 | integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== 211 | 212 | color-support@^1.1.2: 213 | version "1.1.3" 214 | resolved "https://registry.yarnpkg.com/color-support/-/color-support-1.1.3.tgz#93834379a1cc9a0c61f82f52f0d04322251bd5a2" 215 | integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== 216 | 217 | combined-stream@^1.0.8: 218 | version "1.0.8" 219 | resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" 220 | integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== 221 | dependencies: 222 | delayed-stream "~1.0.0" 223 | 224 | concat-map@0.0.1: 225 | version "0.0.1" 226 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 227 | integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== 228 | 229 | concat-stream@^1.5.2: 230 | version "1.6.2" 231 | resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.6.2.tgz#904bdf194cd3122fc675c77fc4ac3d4ff0fd1a34" 232 | integrity sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw== 233 | dependencies: 234 | buffer-from "^1.0.0" 235 | inherits "^2.0.3" 236 | readable-stream "^2.2.2" 237 | typedarray "^0.0.6" 238 | 239 | console-control-strings@^1.0.0, console-control-strings@^1.1.0: 240 | version "1.1.0" 241 | resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" 242 | integrity sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ== 243 | 244 | content-disposition@0.5.4: 245 | version "0.5.4" 246 | resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" 247 | integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== 248 | dependencies: 249 | safe-buffer "5.2.1" 250 | 251 | content-type@~1.0.4, content-type@~1.0.5: 252 | version "1.0.5" 253 | resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.5.tgz#8b773162656d1d1086784c8f23a54ce6d73d7918" 254 | integrity sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA== 255 | 256 | cookie-signature@1.0.6: 257 | version "1.0.6" 258 | resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" 259 | integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== 260 | 261 | cookie@0.7.1: 262 | version "0.7.1" 263 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.7.1.tgz#2f73c42142d5d5cf71310a74fc4ae61670e5dbc9" 264 | integrity sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w== 265 | 266 | core-util-is@~1.0.0: 267 | version "1.0.3" 268 | resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.3.tgz#a6042d3634c2b27e9328f837b965fac83808db85" 269 | integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== 270 | 271 | debug@2.6.9: 272 | version "2.6.9" 273 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" 274 | integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== 275 | dependencies: 276 | ms "2.0.0" 277 | 278 | debug@4, debug@^4: 279 | version "4.4.0" 280 | resolved "https://registry.yarnpkg.com/debug/-/debug-4.4.0.tgz#2b3f2aea2ffeb776477460267377dc8710faba8a" 281 | integrity sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA== 282 | dependencies: 283 | ms "^2.1.3" 284 | 285 | delayed-stream@~1.0.0: 286 | version "1.0.0" 287 | resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" 288 | integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== 289 | 290 | delegates@^1.0.0: 291 | version "1.0.0" 292 | resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" 293 | integrity sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ== 294 | 295 | depd@2.0.0, depd@~2.0.0: 296 | version "2.0.0" 297 | resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" 298 | integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== 299 | 300 | destroy@1.2.0: 301 | version "1.2.0" 302 | resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" 303 | integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== 304 | 305 | detect-libc@^2.0.0: 306 | version "2.0.3" 307 | resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-2.0.3.tgz#f0cd503b40f9939b894697d19ad50895e30cf700" 308 | integrity sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw== 309 | 310 | dicer@0.2.5: 311 | version "0.2.5" 312 | resolved "https://registry.yarnpkg.com/dicer/-/dicer-0.2.5.tgz#5996c086bb33218c812c090bddc09cd12facb70f" 313 | integrity sha512-FDvbtnq7dzlPz0wyYlOExifDEZcu8h+rErEXgfxqmLfRfC/kJidEFh4+effJRO3P0xmfqyPbSMG0LveNRfTKVg== 314 | dependencies: 315 | readable-stream "1.1.x" 316 | streamsearch "0.1.2" 317 | 318 | drange@^1.0.2: 319 | version "1.1.1" 320 | resolved "https://registry.yarnpkg.com/drange/-/drange-1.1.1.tgz#b2aecec2aab82fcef11dbbd7b9e32b83f8f6c0b8" 321 | integrity sha512-pYxfDYpued//QpnLIm4Avk7rsNtAtQkUES2cwAYSvD/wd2pKD71gN2Ebj3e7klzXwjocvE8c5vx/1fxwpqmSxA== 322 | 323 | dunder-proto@^1.0.1: 324 | version "1.0.1" 325 | resolved "https://registry.yarnpkg.com/dunder-proto/-/dunder-proto-1.0.1.tgz#d7ae667e1dc83482f8b70fd0f6eefc50da30f58a" 326 | integrity sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A== 327 | dependencies: 328 | call-bind-apply-helpers "^1.0.1" 329 | es-errors "^1.3.0" 330 | gopd "^1.2.0" 331 | 332 | ecdsa-sig-formatter@1.0.11: 333 | version "1.0.11" 334 | resolved "https://registry.yarnpkg.com/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz#ae0f0fa2d85045ef14a817daa3ce9acd0489e5bf" 335 | integrity sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ== 336 | dependencies: 337 | safe-buffer "^5.0.1" 338 | 339 | ee-first@1.1.1: 340 | version "1.1.1" 341 | resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" 342 | integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== 343 | 344 | emoji-regex@^8.0.0: 345 | version "8.0.0" 346 | resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" 347 | integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== 348 | 349 | encodeurl@~1.0.2: 350 | version "1.0.2" 351 | resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" 352 | integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== 353 | 354 | encodeurl@~2.0.0: 355 | version "2.0.0" 356 | resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-2.0.0.tgz#7b8ea898077d7e409d3ac45474ea38eaf0857a58" 357 | integrity sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg== 358 | 359 | es-define-property@^1.0.1: 360 | version "1.0.1" 361 | resolved "https://registry.yarnpkg.com/es-define-property/-/es-define-property-1.0.1.tgz#983eb2f9a6724e9303f61addf011c72e09e0b0fa" 362 | integrity sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g== 363 | 364 | es-errors@^1.3.0: 365 | version "1.3.0" 366 | resolved "https://registry.yarnpkg.com/es-errors/-/es-errors-1.3.0.tgz#05f75a25dab98e4fb1dcd5e1472c0546d5057c8f" 367 | integrity sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw== 368 | 369 | es-object-atoms@^1.0.0: 370 | version "1.1.1" 371 | resolved "https://registry.yarnpkg.com/es-object-atoms/-/es-object-atoms-1.1.1.tgz#1c4f2c4837327597ce69d2ca190a7fdd172338c1" 372 | integrity sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA== 373 | dependencies: 374 | es-errors "^1.3.0" 375 | 376 | escape-html@~1.0.3: 377 | version "1.0.3" 378 | resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" 379 | integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== 380 | 381 | etag@~1.8.1: 382 | version "1.8.1" 383 | resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" 384 | integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== 385 | 386 | express@^4.21.2: 387 | version "4.21.2" 388 | resolved "https://registry.yarnpkg.com/express/-/express-4.21.2.tgz#cf250e48362174ead6cea4a566abef0162c1ec32" 389 | integrity sha512-28HqgMZAmih1Czt9ny7qr6ek2qddF4FclbMzwhCREB6OFfH+rXAnuNCwo1/wFvrtbgsQDb4kSbX9de9lFbrXnA== 390 | dependencies: 391 | accepts "~1.3.8" 392 | array-flatten "1.1.1" 393 | body-parser "1.20.3" 394 | content-disposition "0.5.4" 395 | content-type "~1.0.4" 396 | cookie "0.7.1" 397 | cookie-signature "1.0.6" 398 | debug "2.6.9" 399 | depd "2.0.0" 400 | encodeurl "~2.0.0" 401 | escape-html "~1.0.3" 402 | etag "~1.8.1" 403 | finalhandler "1.3.1" 404 | fresh "0.5.2" 405 | http-errors "2.0.0" 406 | merge-descriptors "1.0.3" 407 | methods "~1.1.2" 408 | on-finished "2.4.1" 409 | parseurl "~1.3.3" 410 | path-to-regexp "0.1.12" 411 | proxy-addr "~2.0.7" 412 | qs "6.13.0" 413 | range-parser "~1.2.1" 414 | safe-buffer "5.2.1" 415 | send "0.19.0" 416 | serve-static "1.16.2" 417 | setprototypeof "1.2.0" 418 | statuses "2.0.1" 419 | type-is "~1.6.18" 420 | utils-merge "1.0.1" 421 | vary "~1.1.2" 422 | 423 | fill-range@^7.1.1: 424 | version "7.1.1" 425 | resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.1.1.tgz#44265d3cac07e3ea7dc247516380643754a05292" 426 | integrity sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg== 427 | dependencies: 428 | to-regex-range "^5.0.1" 429 | 430 | finalhandler@1.3.1: 431 | version "1.3.1" 432 | resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.3.1.tgz#0c575f1d1d324ddd1da35ad7ece3df7d19088019" 433 | integrity sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ== 434 | dependencies: 435 | debug "2.6.9" 436 | encodeurl "~2.0.0" 437 | escape-html "~1.0.3" 438 | on-finished "2.4.1" 439 | parseurl "~1.3.3" 440 | statuses "2.0.1" 441 | unpipe "~1.0.0" 442 | 443 | follow-redirects@^1.15.6: 444 | version "1.15.9" 445 | resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.9.tgz#a604fa10e443bf98ca94228d9eebcc2e8a2c8ee1" 446 | integrity sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ== 447 | 448 | form-data@^4.0.0: 449 | version "4.0.1" 450 | resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.1.tgz#ba1076daaaa5bfd7e99c1a6cb02aa0a5cff90d48" 451 | integrity sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw== 452 | dependencies: 453 | asynckit "^0.4.0" 454 | combined-stream "^1.0.8" 455 | mime-types "^2.1.12" 456 | 457 | forwarded@0.2.0: 458 | version "0.2.0" 459 | resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" 460 | integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== 461 | 462 | fresh@0.5.2: 463 | version "0.5.2" 464 | resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" 465 | integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== 466 | 467 | fs-minipass@^2.0.0: 468 | version "2.1.0" 469 | resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" 470 | integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== 471 | dependencies: 472 | minipass "^3.0.0" 473 | 474 | fs.realpath@^1.0.0: 475 | version "1.0.0" 476 | resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" 477 | integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== 478 | 479 | fsevents@~2.3.2: 480 | version "2.3.3" 481 | resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6" 482 | integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw== 483 | 484 | function-bind@^1.1.2: 485 | version "1.1.2" 486 | resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" 487 | integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== 488 | 489 | gauge@^3.0.0: 490 | version "3.0.2" 491 | resolved "https://registry.yarnpkg.com/gauge/-/gauge-3.0.2.tgz#03bf4441c044383908bcfa0656ad91803259b395" 492 | integrity sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q== 493 | dependencies: 494 | aproba "^1.0.3 || ^2.0.0" 495 | color-support "^1.1.2" 496 | console-control-strings "^1.0.0" 497 | has-unicode "^2.0.1" 498 | object-assign "^4.1.1" 499 | signal-exit "^3.0.0" 500 | string-width "^4.2.3" 501 | strip-ansi "^6.0.1" 502 | wide-align "^1.1.2" 503 | 504 | get-intrinsic@^1.2.5, get-intrinsic@^1.2.6: 505 | version "1.2.7" 506 | resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.7.tgz#dcfcb33d3272e15f445d15124bc0a216189b9044" 507 | integrity sha512-VW6Pxhsrk0KAOqs3WEd0klDiF/+V7gQOpAvY1jVU/LHmaD/kQO4523aiJuikX/QAKYiW6x8Jh+RJej1almdtCA== 508 | dependencies: 509 | call-bind-apply-helpers "^1.0.1" 510 | es-define-property "^1.0.1" 511 | es-errors "^1.3.0" 512 | es-object-atoms "^1.0.0" 513 | function-bind "^1.1.2" 514 | get-proto "^1.0.0" 515 | gopd "^1.2.0" 516 | has-symbols "^1.1.0" 517 | hasown "^2.0.2" 518 | math-intrinsics "^1.1.0" 519 | 520 | get-proto@^1.0.0: 521 | version "1.0.1" 522 | resolved "https://registry.yarnpkg.com/get-proto/-/get-proto-1.0.1.tgz#150b3f2743869ef3e851ec0c49d15b1d14d00ee1" 523 | integrity sha512-sTSfBjoXBp89JvIKIefqw7U2CCebsc74kiY6awiGogKtoSGbgjYE/G/+l9sF3MWFPNc9IcoOC4ODfKHfxFmp0g== 524 | dependencies: 525 | dunder-proto "^1.0.1" 526 | es-object-atoms "^1.0.0" 527 | 528 | glob-parent@~5.1.2: 529 | version "5.1.2" 530 | resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" 531 | integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== 532 | dependencies: 533 | is-glob "^4.0.1" 534 | 535 | glob@^7.1.3: 536 | version "7.2.3" 537 | resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" 538 | integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== 539 | dependencies: 540 | fs.realpath "^1.0.0" 541 | inflight "^1.0.4" 542 | inherits "2" 543 | minimatch "^3.1.1" 544 | once "^1.3.0" 545 | path-is-absolute "^1.0.0" 546 | 547 | gopd@^1.2.0: 548 | version "1.2.0" 549 | resolved "https://registry.yarnpkg.com/gopd/-/gopd-1.2.0.tgz#89f56b8217bdbc8802bd299df6d7f1081d7e51a1" 550 | integrity sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg== 551 | 552 | has-flag@^3.0.0: 553 | version "3.0.0" 554 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" 555 | integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== 556 | 557 | has-symbols@^1.1.0: 558 | version "1.1.0" 559 | resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.1.0.tgz#fc9c6a783a084951d0b971fe1018de813707a338" 560 | integrity sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ== 561 | 562 | has-unicode@^2.0.1: 563 | version "2.0.1" 564 | resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" 565 | integrity sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ== 566 | 567 | hasown@^2.0.2: 568 | version "2.0.2" 569 | resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.2.tgz#003eaf91be7adc372e84ec59dc37252cedb80003" 570 | integrity sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ== 571 | dependencies: 572 | function-bind "^1.1.2" 573 | 574 | http-errors@2.0.0: 575 | version "2.0.0" 576 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" 577 | integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== 578 | dependencies: 579 | depd "2.0.0" 580 | inherits "2.0.4" 581 | setprototypeof "1.2.0" 582 | statuses "2.0.1" 583 | toidentifier "1.0.1" 584 | 585 | https-proxy-agent@^5.0.0: 586 | version "5.0.1" 587 | resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" 588 | integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== 589 | dependencies: 590 | agent-base "6" 591 | debug "4" 592 | 593 | iconv-lite@0.4.24: 594 | version "0.4.24" 595 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" 596 | integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== 597 | dependencies: 598 | safer-buffer ">= 2.1.2 < 3" 599 | 600 | ignore-by-default@^1.0.1: 601 | version "1.0.1" 602 | resolved "https://registry.yarnpkg.com/ignore-by-default/-/ignore-by-default-1.0.1.tgz#48ca6d72f6c6a3af00a9ad4ae6876be3889e2b09" 603 | integrity sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA== 604 | 605 | inflight@^1.0.4: 606 | version "1.0.6" 607 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 608 | integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== 609 | dependencies: 610 | once "^1.3.0" 611 | wrappy "1" 612 | 613 | inherits@2, inherits@2.0.4, inherits@^2.0.3, inherits@~2.0.1, inherits@~2.0.3: 614 | version "2.0.4" 615 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" 616 | integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== 617 | 618 | ipaddr.js@1.9.1: 619 | version "1.9.1" 620 | resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" 621 | integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== 622 | 623 | is-binary-path@~2.1.0: 624 | version "2.1.0" 625 | resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" 626 | integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== 627 | dependencies: 628 | binary-extensions "^2.0.0" 629 | 630 | is-extglob@^2.1.1: 631 | version "2.1.1" 632 | resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" 633 | integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== 634 | 635 | is-fullwidth-code-point@^3.0.0: 636 | version "3.0.0" 637 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" 638 | integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== 639 | 640 | is-glob@^4.0.1, is-glob@~4.0.1: 641 | version "4.0.3" 642 | resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" 643 | integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== 644 | dependencies: 645 | is-extglob "^2.1.1" 646 | 647 | is-number@^7.0.0: 648 | version "7.0.0" 649 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" 650 | integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== 651 | 652 | isarray@0.0.1: 653 | version "0.0.1" 654 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" 655 | integrity sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ== 656 | 657 | isarray@~1.0.0: 658 | version "1.0.0" 659 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" 660 | integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== 661 | 662 | jsonwebtoken@^9.0.2: 663 | version "9.0.2" 664 | resolved "https://registry.yarnpkg.com/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz#65ff91f4abef1784697d40952bb1998c504caaf3" 665 | integrity sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ== 666 | dependencies: 667 | jws "^3.2.2" 668 | lodash.includes "^4.3.0" 669 | lodash.isboolean "^3.0.3" 670 | lodash.isinteger "^4.0.4" 671 | lodash.isnumber "^3.0.3" 672 | lodash.isplainobject "^4.0.6" 673 | lodash.isstring "^4.0.1" 674 | lodash.once "^4.0.0" 675 | ms "^2.1.1" 676 | semver "^7.5.4" 677 | 678 | jwa@^1.4.1: 679 | version "1.4.1" 680 | resolved "https://registry.yarnpkg.com/jwa/-/jwa-1.4.1.tgz#743c32985cb9e98655530d53641b66c8645b039a" 681 | integrity sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA== 682 | dependencies: 683 | buffer-equal-constant-time "1.0.1" 684 | ecdsa-sig-formatter "1.0.11" 685 | safe-buffer "^5.0.1" 686 | 687 | jws@^3.2.2: 688 | version "3.2.2" 689 | resolved "https://registry.yarnpkg.com/jws/-/jws-3.2.2.tgz#001099f3639468c9414000e99995fa52fb478304" 690 | integrity sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA== 691 | dependencies: 692 | jwa "^1.4.1" 693 | safe-buffer "^5.0.1" 694 | 695 | lodash.includes@^4.3.0: 696 | version "4.3.0" 697 | resolved "https://registry.yarnpkg.com/lodash.includes/-/lodash.includes-4.3.0.tgz#60bb98a87cb923c68ca1e51325483314849f553f" 698 | integrity sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w== 699 | 700 | lodash.isboolean@^3.0.3: 701 | version "3.0.3" 702 | resolved "https://registry.yarnpkg.com/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz#6c2e171db2a257cd96802fd43b01b20d5f5870f6" 703 | integrity sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg== 704 | 705 | lodash.isinteger@^4.0.4: 706 | version "4.0.4" 707 | resolved "https://registry.yarnpkg.com/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz#619c0af3d03f8b04c31f5882840b77b11cd68343" 708 | integrity sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA== 709 | 710 | lodash.isnumber@^3.0.3: 711 | version "3.0.3" 712 | resolved "https://registry.yarnpkg.com/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz#3ce76810c5928d03352301ac287317f11c0b1ffc" 713 | integrity sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw== 714 | 715 | lodash.isplainobject@^4.0.6: 716 | version "4.0.6" 717 | resolved "https://registry.yarnpkg.com/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz#7c526a52d89b45c45cc690b88163be0497f550cb" 718 | integrity sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA== 719 | 720 | lodash.isstring@^4.0.1: 721 | version "4.0.1" 722 | resolved "https://registry.yarnpkg.com/lodash.isstring/-/lodash.isstring-4.0.1.tgz#d527dfb5456eca7cc9bb95d5daeaf88ba54a5451" 723 | integrity sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw== 724 | 725 | lodash.once@^4.0.0: 726 | version "4.1.1" 727 | resolved "https://registry.yarnpkg.com/lodash.once/-/lodash.once-4.1.1.tgz#0dd3971213c7c56df880977d504c88fb471a97ac" 728 | integrity sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg== 729 | 730 | make-dir@^3.1.0: 731 | version "3.1.0" 732 | resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" 733 | integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== 734 | dependencies: 735 | semver "^6.0.0" 736 | 737 | math-intrinsics@^1.1.0: 738 | version "1.1.0" 739 | resolved "https://registry.yarnpkg.com/math-intrinsics/-/math-intrinsics-1.1.0.tgz#a0dd74be81e2aa5c2f27e65ce283605ee4e2b7f9" 740 | integrity sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g== 741 | 742 | media-typer@0.3.0: 743 | version "0.3.0" 744 | resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" 745 | integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== 746 | 747 | merge-descriptors@1.0.3: 748 | version "1.0.3" 749 | resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.3.tgz#d80319a65f3c7935351e5cfdac8f9318504dbed5" 750 | integrity sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ== 751 | 752 | methods@~1.1.2: 753 | version "1.1.2" 754 | resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" 755 | integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== 756 | 757 | mime-db@1.52.0: 758 | version "1.52.0" 759 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" 760 | integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== 761 | 762 | mime-types@^2.1.12, mime-types@~2.1.24, mime-types@~2.1.34: 763 | version "2.1.35" 764 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" 765 | integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== 766 | dependencies: 767 | mime-db "1.52.0" 768 | 769 | mime@1.6.0: 770 | version "1.6.0" 771 | resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" 772 | integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== 773 | 774 | minimatch@^3.1.1, minimatch@^3.1.2: 775 | version "3.1.2" 776 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" 777 | integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== 778 | dependencies: 779 | brace-expansion "^1.1.7" 780 | 781 | minimist@^1.2.6: 782 | version "1.2.8" 783 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" 784 | integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== 785 | 786 | minipass@^3.0.0: 787 | version "3.3.6" 788 | resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.3.6.tgz#7bba384db3a1520d18c9c0e5251c3444e95dd94a" 789 | integrity sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw== 790 | dependencies: 791 | yallist "^4.0.0" 792 | 793 | minipass@^5.0.0: 794 | version "5.0.0" 795 | resolved "https://registry.yarnpkg.com/minipass/-/minipass-5.0.0.tgz#3e9788ffb90b694a5d0ec94479a45b5d8738133d" 796 | integrity sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ== 797 | 798 | minizlib@^2.1.1: 799 | version "2.1.2" 800 | resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" 801 | integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== 802 | dependencies: 803 | minipass "^3.0.0" 804 | yallist "^4.0.0" 805 | 806 | mkdirp@^0.5.4: 807 | version "0.5.6" 808 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.6.tgz#7def03d2432dcae4ba1d611445c48396062255f6" 809 | integrity sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw== 810 | dependencies: 811 | minimist "^1.2.6" 812 | 813 | mkdirp@^1.0.3: 814 | version "1.0.4" 815 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" 816 | integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== 817 | 818 | morgan@^1.10.0: 819 | version "1.10.0" 820 | resolved "https://registry.yarnpkg.com/morgan/-/morgan-1.10.0.tgz#091778abc1fc47cd3509824653dae1faab6b17d7" 821 | integrity sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ== 822 | dependencies: 823 | basic-auth "~2.0.1" 824 | debug "2.6.9" 825 | depd "~2.0.0" 826 | on-finished "~2.3.0" 827 | on-headers "~1.0.2" 828 | 829 | ms@2.0.0: 830 | version "2.0.0" 831 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" 832 | integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== 833 | 834 | ms@2.1.3, ms@^2.1.1, ms@^2.1.3: 835 | version "2.1.3" 836 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" 837 | integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== 838 | 839 | multer@^1.4.4: 840 | version "1.4.4" 841 | resolved "https://registry.yarnpkg.com/multer/-/multer-1.4.4.tgz#e2bc6cac0df57a8832b858d7418ccaa8ebaf7d8c" 842 | integrity sha512-2wY2+xD4udX612aMqMcB8Ws2Voq6NIUPEtD1be6m411T4uDH/VtL9i//xvcyFlTVfRdaBsk7hV5tgrGQqhuBiw== 843 | dependencies: 844 | append-field "^1.0.0" 845 | busboy "^0.2.11" 846 | concat-stream "^1.5.2" 847 | mkdirp "^0.5.4" 848 | object-assign "^4.1.1" 849 | on-finished "^2.3.0" 850 | type-is "^1.6.4" 851 | xtend "^4.0.0" 852 | 853 | mysql@^2.18.1: 854 | version "2.18.1" 855 | resolved "https://registry.yarnpkg.com/mysql/-/mysql-2.18.1.tgz#2254143855c5a8c73825e4522baf2ea021766717" 856 | integrity sha512-Bca+gk2YWmqp2Uf6k5NFEurwY/0td0cpebAucFpY/3jhrwrVGuxU2uQFCHjU19SJfje0yQvi+rVWdq78hR5lig== 857 | dependencies: 858 | bignumber.js "9.0.0" 859 | readable-stream "2.3.7" 860 | safe-buffer "5.1.2" 861 | sqlstring "2.3.1" 862 | 863 | negotiator@0.6.3: 864 | version "0.6.3" 865 | resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" 866 | integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== 867 | 868 | node-addon-api@^5.0.0: 869 | version "5.1.0" 870 | resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-5.1.0.tgz#49da1ca055e109a23d537e9de43c09cca21eb762" 871 | integrity sha512-eh0GgfEkpnoWDq+VY8OyvYhFEzBk6jIYbRKdIlyTiAXIVJ8PyBaKb0rp7oDtoddbdoHWhq8wwr+XZ81F1rpNdA== 872 | 873 | node-fetch@^2.6.7: 874 | version "2.7.0" 875 | resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.7.0.tgz#d0f0fa6e3e2dc1d27efcd8ad99d550bda94d187d" 876 | integrity sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A== 877 | dependencies: 878 | whatwg-url "^5.0.0" 879 | 880 | nodemon@^3.1.9: 881 | version "3.1.9" 882 | resolved "https://registry.yarnpkg.com/nodemon/-/nodemon-3.1.9.tgz#df502cdc3b120e1c3c0c6e4152349019efa7387b" 883 | integrity sha512-hdr1oIb2p6ZSxu3PB2JWWYS7ZQ0qvaZsc3hK8DR8f02kRzc8rjYmxAIvdz+aYC+8F2IjNaB7HMcSDg8nQpJxyg== 884 | dependencies: 885 | chokidar "^3.5.2" 886 | debug "^4" 887 | ignore-by-default "^1.0.1" 888 | minimatch "^3.1.2" 889 | pstree.remy "^1.1.8" 890 | semver "^7.5.3" 891 | simple-update-notifier "^2.0.0" 892 | supports-color "^5.5.0" 893 | touch "^3.1.0" 894 | undefsafe "^2.0.5" 895 | 896 | nopt@^5.0.0: 897 | version "5.0.0" 898 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-5.0.0.tgz#530942bb58a512fccafe53fe210f13a25355dc88" 899 | integrity sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ== 900 | dependencies: 901 | abbrev "1" 902 | 903 | normalize-path@^3.0.0, normalize-path@~3.0.0: 904 | version "3.0.0" 905 | resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" 906 | integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== 907 | 908 | npmlog@^5.0.1: 909 | version "5.0.1" 910 | resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-5.0.1.tgz#f06678e80e29419ad67ab964e0fa69959c1eb8b0" 911 | integrity sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw== 912 | dependencies: 913 | are-we-there-yet "^2.0.0" 914 | console-control-strings "^1.1.0" 915 | gauge "^3.0.0" 916 | set-blocking "^2.0.0" 917 | 918 | object-assign@^4.1.1: 919 | version "4.1.1" 920 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 921 | integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== 922 | 923 | object-inspect@^1.13.3: 924 | version "1.13.3" 925 | resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.3.tgz#f14c183de51130243d6d18ae149375ff50ea488a" 926 | integrity sha512-kDCGIbxkDSXE3euJZZXzc6to7fCrKHNI/hSRQnRuQ+BWjFNzZwiFF8fj/6o2t2G9/jTj8PSIYTfCLelLZEeRpA== 927 | 928 | on-finished@2.4.1, on-finished@^2.3.0: 929 | version "2.4.1" 930 | resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" 931 | integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== 932 | dependencies: 933 | ee-first "1.1.1" 934 | 935 | on-finished@~2.3.0: 936 | version "2.3.0" 937 | resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" 938 | integrity sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww== 939 | dependencies: 940 | ee-first "1.1.1" 941 | 942 | on-headers@~1.0.2: 943 | version "1.0.2" 944 | resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.2.tgz#772b0ae6aaa525c399e489adfad90c403eb3c28f" 945 | integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== 946 | 947 | once@^1.3.0: 948 | version "1.4.0" 949 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 950 | integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== 951 | dependencies: 952 | wrappy "1" 953 | 954 | parseurl@~1.3.3: 955 | version "1.3.3" 956 | resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" 957 | integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== 958 | 959 | path-is-absolute@^1.0.0: 960 | version "1.0.1" 961 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 962 | integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== 963 | 964 | path-to-regexp@0.1.12: 965 | version "0.1.12" 966 | resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.12.tgz#d5e1a12e478a976d432ef3c58d534b9923164bb7" 967 | integrity sha512-RA1GjUVMnvYFxuqovrEqZoxxW5NUZqbwKtYz/Tt7nXerk0LbLblQmrsgdeOxV5SFHf0UDggjS/bSeOZwt1pmEQ== 968 | 969 | picomatch@^2.0.4, picomatch@^2.2.1: 970 | version "2.3.1" 971 | resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" 972 | integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== 973 | 974 | process-nextick-args@~2.0.0: 975 | version "2.0.1" 976 | resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" 977 | integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== 978 | 979 | proxy-addr@~2.0.7: 980 | version "2.0.7" 981 | resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" 982 | integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== 983 | dependencies: 984 | forwarded "0.2.0" 985 | ipaddr.js "1.9.1" 986 | 987 | proxy-from-env@^1.1.0: 988 | version "1.1.0" 989 | resolved "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2" 990 | integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== 991 | 992 | pstree.remy@^1.1.8: 993 | version "1.1.8" 994 | resolved "https://registry.yarnpkg.com/pstree.remy/-/pstree.remy-1.1.8.tgz#c242224f4a67c21f686839bbdb4ac282b8373d3a" 995 | integrity sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w== 996 | 997 | qs@6.13.0: 998 | version "6.13.0" 999 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.13.0.tgz#6ca3bd58439f7e245655798997787b0d88a51906" 1000 | integrity sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg== 1001 | dependencies: 1002 | side-channel "^1.0.6" 1003 | 1004 | randexp@^0.5.3: 1005 | version "0.5.3" 1006 | resolved "https://registry.yarnpkg.com/randexp/-/randexp-0.5.3.tgz#f31c2de3148b30bdeb84b7c3f59b0ebb9fec3738" 1007 | integrity sha512-U+5l2KrcMNOUPYvazA3h5ekF80FHTUG+87SEAmHZmolh1M+i/WyTCxVzmi+tidIa1tM4BSe8g2Y/D3loWDjj+w== 1008 | dependencies: 1009 | drange "^1.0.2" 1010 | ret "^0.2.0" 1011 | 1012 | range-parser@~1.2.1: 1013 | version "1.2.1" 1014 | resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" 1015 | integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== 1016 | 1017 | raw-body@2.5.2: 1018 | version "2.5.2" 1019 | resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.2.tgz#99febd83b90e08975087e8f1f9419a149366b68a" 1020 | integrity sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA== 1021 | dependencies: 1022 | bytes "3.1.2" 1023 | http-errors "2.0.0" 1024 | iconv-lite "0.4.24" 1025 | unpipe "1.0.0" 1026 | 1027 | readable-stream@1.1.x: 1028 | version "1.1.14" 1029 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.14.tgz#7cf4c54ef648e3813084c636dd2079e166c081d9" 1030 | integrity sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ== 1031 | dependencies: 1032 | core-util-is "~1.0.0" 1033 | inherits "~2.0.1" 1034 | isarray "0.0.1" 1035 | string_decoder "~0.10.x" 1036 | 1037 | readable-stream@2.3.7: 1038 | version "2.3.7" 1039 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" 1040 | integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== 1041 | dependencies: 1042 | core-util-is "~1.0.0" 1043 | inherits "~2.0.3" 1044 | isarray "~1.0.0" 1045 | process-nextick-args "~2.0.0" 1046 | safe-buffer "~5.1.1" 1047 | string_decoder "~1.1.1" 1048 | util-deprecate "~1.0.1" 1049 | 1050 | readable-stream@^2.2.2: 1051 | version "2.3.8" 1052 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.8.tgz#91125e8042bba1b9887f49345f6277027ce8be9b" 1053 | integrity sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA== 1054 | dependencies: 1055 | core-util-is "~1.0.0" 1056 | inherits "~2.0.3" 1057 | isarray "~1.0.0" 1058 | process-nextick-args "~2.0.0" 1059 | safe-buffer "~5.1.1" 1060 | string_decoder "~1.1.1" 1061 | util-deprecate "~1.0.1" 1062 | 1063 | readable-stream@^3.6.0: 1064 | version "3.6.2" 1065 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" 1066 | integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== 1067 | dependencies: 1068 | inherits "^2.0.3" 1069 | string_decoder "^1.1.1" 1070 | util-deprecate "^1.0.1" 1071 | 1072 | readdirp@~3.6.0: 1073 | version "3.6.0" 1074 | resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" 1075 | integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== 1076 | dependencies: 1077 | picomatch "^2.2.1" 1078 | 1079 | ret@^0.2.0: 1080 | version "0.2.2" 1081 | resolved "https://registry.yarnpkg.com/ret/-/ret-0.2.2.tgz#b6861782a1f4762dce43402a71eb7a283f44573c" 1082 | integrity sha512-M0b3YWQs7R3Z917WRQy1HHA7Ba7D8hvZg6UE5mLykJxQVE2ju0IXbGlaHPPlkY+WN7wFP+wUMXmBFA0aV6vYGQ== 1083 | 1084 | rimraf@^3.0.2: 1085 | version "3.0.2" 1086 | resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" 1087 | integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== 1088 | dependencies: 1089 | glob "^7.1.3" 1090 | 1091 | safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: 1092 | version "5.1.2" 1093 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" 1094 | integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== 1095 | 1096 | safe-buffer@5.2.1, safe-buffer@^5.0.1, safe-buffer@~5.2.0: 1097 | version "5.2.1" 1098 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" 1099 | integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== 1100 | 1101 | "safer-buffer@>= 2.1.2 < 3": 1102 | version "2.1.2" 1103 | resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" 1104 | integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== 1105 | 1106 | semver@^6.0.0: 1107 | version "6.3.1" 1108 | resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.1.tgz#556d2ef8689146e46dcea4bfdd095f3434dffcb4" 1109 | integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== 1110 | 1111 | semver@^7.3.5, semver@^7.5.3, semver@^7.5.4: 1112 | version "7.7.0" 1113 | resolved "https://registry.yarnpkg.com/semver/-/semver-7.7.0.tgz#9c6fe61d0c6f9fa9e26575162ee5a9180361b09c" 1114 | integrity sha512-DrfFnPzblFmNrIZzg5RzHegbiRWg7KMR7btwi2yjHwx06zsUbO5g613sVwEV7FTwmzJu+Io0lJe2GJ3LxqpvBQ== 1115 | 1116 | send@0.19.0: 1117 | version "0.19.0" 1118 | resolved "https://registry.yarnpkg.com/send/-/send-0.19.0.tgz#bbc5a388c8ea6c048967049dbeac0e4a3f09d7f8" 1119 | integrity sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw== 1120 | dependencies: 1121 | debug "2.6.9" 1122 | depd "2.0.0" 1123 | destroy "1.2.0" 1124 | encodeurl "~1.0.2" 1125 | escape-html "~1.0.3" 1126 | etag "~1.8.1" 1127 | fresh "0.5.2" 1128 | http-errors "2.0.0" 1129 | mime "1.6.0" 1130 | ms "2.1.3" 1131 | on-finished "2.4.1" 1132 | range-parser "~1.2.1" 1133 | statuses "2.0.1" 1134 | 1135 | serve-static@1.16.2: 1136 | version "1.16.2" 1137 | resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.16.2.tgz#b6a5343da47f6bdd2673848bf45754941e803296" 1138 | integrity sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw== 1139 | dependencies: 1140 | encodeurl "~2.0.0" 1141 | escape-html "~1.0.3" 1142 | parseurl "~1.3.3" 1143 | send "0.19.0" 1144 | 1145 | set-blocking@^2.0.0: 1146 | version "2.0.0" 1147 | resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" 1148 | integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== 1149 | 1150 | setprototypeof@1.2.0: 1151 | version "1.2.0" 1152 | resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" 1153 | integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== 1154 | 1155 | side-channel-list@^1.0.0: 1156 | version "1.0.0" 1157 | resolved "https://registry.yarnpkg.com/side-channel-list/-/side-channel-list-1.0.0.tgz#10cb5984263115d3b7a0e336591e290a830af8ad" 1158 | integrity sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA== 1159 | dependencies: 1160 | es-errors "^1.3.0" 1161 | object-inspect "^1.13.3" 1162 | 1163 | side-channel-map@^1.0.1: 1164 | version "1.0.1" 1165 | resolved "https://registry.yarnpkg.com/side-channel-map/-/side-channel-map-1.0.1.tgz#d6bb6b37902c6fef5174e5f533fab4c732a26f42" 1166 | integrity sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA== 1167 | dependencies: 1168 | call-bound "^1.0.2" 1169 | es-errors "^1.3.0" 1170 | get-intrinsic "^1.2.5" 1171 | object-inspect "^1.13.3" 1172 | 1173 | side-channel-weakmap@^1.0.2: 1174 | version "1.0.2" 1175 | resolved "https://registry.yarnpkg.com/side-channel-weakmap/-/side-channel-weakmap-1.0.2.tgz#11dda19d5368e40ce9ec2bdc1fb0ecbc0790ecea" 1176 | integrity sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A== 1177 | dependencies: 1178 | call-bound "^1.0.2" 1179 | es-errors "^1.3.0" 1180 | get-intrinsic "^1.2.5" 1181 | object-inspect "^1.13.3" 1182 | side-channel-map "^1.0.1" 1183 | 1184 | side-channel@^1.0.6: 1185 | version "1.1.0" 1186 | resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.1.0.tgz#c3fcff9c4da932784873335ec9765fa94ff66bc9" 1187 | integrity sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw== 1188 | dependencies: 1189 | es-errors "^1.3.0" 1190 | object-inspect "^1.13.3" 1191 | side-channel-list "^1.0.0" 1192 | side-channel-map "^1.0.1" 1193 | side-channel-weakmap "^1.0.2" 1194 | 1195 | signal-exit@^3.0.0: 1196 | version "3.0.7" 1197 | resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" 1198 | integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== 1199 | 1200 | simple-update-notifier@^2.0.0: 1201 | version "2.0.0" 1202 | resolved "https://registry.yarnpkg.com/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz#d70b92bdab7d6d90dfd73931195a30b6e3d7cebb" 1203 | integrity sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w== 1204 | dependencies: 1205 | semver "^7.5.3" 1206 | 1207 | sqlstring@2.3.1: 1208 | version "2.3.1" 1209 | resolved "https://registry.yarnpkg.com/sqlstring/-/sqlstring-2.3.1.tgz#475393ff9e91479aea62dcaf0ca3d14983a7fb40" 1210 | integrity sha512-ooAzh/7dxIG5+uDik1z/Rd1vli0+38izZhGzSa34FwR7IbelPWCCKSNIl8jlL/F7ERvy8CB2jNeM1E9i9mXMAQ== 1211 | 1212 | statuses@2.0.1: 1213 | version "2.0.1" 1214 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" 1215 | integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== 1216 | 1217 | streamsearch@0.1.2: 1218 | version "0.1.2" 1219 | resolved "https://registry.yarnpkg.com/streamsearch/-/streamsearch-0.1.2.tgz#808b9d0e56fc273d809ba57338e929919a1a9f1a" 1220 | integrity sha512-jos8u++JKm0ARcSUTAZXOVC0mSox7Bhn6sBgty73P1f3JGf7yG2clTbBNHUdde/kdvP2FESam+vM6l8jBrNxHA== 1221 | 1222 | "string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.2.3: 1223 | version "4.2.3" 1224 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" 1225 | integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== 1226 | dependencies: 1227 | emoji-regex "^8.0.0" 1228 | is-fullwidth-code-point "^3.0.0" 1229 | strip-ansi "^6.0.1" 1230 | 1231 | string_decoder@^1.1.1: 1232 | version "1.3.0" 1233 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" 1234 | integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== 1235 | dependencies: 1236 | safe-buffer "~5.2.0" 1237 | 1238 | string_decoder@~0.10.x: 1239 | version "0.10.31" 1240 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94" 1241 | integrity sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ== 1242 | 1243 | string_decoder@~1.1.1: 1244 | version "1.1.1" 1245 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" 1246 | integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== 1247 | dependencies: 1248 | safe-buffer "~5.1.0" 1249 | 1250 | strip-ansi@^6.0.1: 1251 | version "6.0.1" 1252 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" 1253 | integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== 1254 | dependencies: 1255 | ansi-regex "^5.0.1" 1256 | 1257 | supports-color@^5.5.0: 1258 | version "5.5.0" 1259 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" 1260 | integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== 1261 | dependencies: 1262 | has-flag "^3.0.0" 1263 | 1264 | tar@^6.1.11: 1265 | version "6.2.1" 1266 | resolved "https://registry.yarnpkg.com/tar/-/tar-6.2.1.tgz#717549c541bc3c2af15751bea94b1dd068d4b03a" 1267 | integrity sha512-DZ4yORTwrbTj/7MZYq2w+/ZFdI6OZ/f9SFHR+71gIVUZhOQPHzVCLpvRnPgyaMpfWxxk/4ONva3GQSyNIKRv6A== 1268 | dependencies: 1269 | chownr "^2.0.0" 1270 | fs-minipass "^2.0.0" 1271 | minipass "^5.0.0" 1272 | minizlib "^2.1.1" 1273 | mkdirp "^1.0.3" 1274 | yallist "^4.0.0" 1275 | 1276 | to-regex-range@^5.0.1: 1277 | version "5.0.1" 1278 | resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" 1279 | integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== 1280 | dependencies: 1281 | is-number "^7.0.0" 1282 | 1283 | toidentifier@1.0.1: 1284 | version "1.0.1" 1285 | resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" 1286 | integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== 1287 | 1288 | touch@^3.1.0: 1289 | version "3.1.1" 1290 | resolved "https://registry.yarnpkg.com/touch/-/touch-3.1.1.tgz#097a23d7b161476435e5c1344a95c0f75b4a5694" 1291 | integrity sha512-r0eojU4bI8MnHr8c5bNo7lJDdI2qXlWWJk6a9EAFG7vbhTjElYhBVS3/miuE0uOuoLdb8Mc/rVfsmm6eo5o9GA== 1292 | 1293 | tr46@~0.0.3: 1294 | version "0.0.3" 1295 | resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" 1296 | integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== 1297 | 1298 | type-is@^1.6.4, type-is@~1.6.18: 1299 | version "1.6.18" 1300 | resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" 1301 | integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== 1302 | dependencies: 1303 | media-typer "0.3.0" 1304 | mime-types "~2.1.24" 1305 | 1306 | typedarray@^0.0.6: 1307 | version "0.0.6" 1308 | resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" 1309 | integrity sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA== 1310 | 1311 | undefsafe@^2.0.5: 1312 | version "2.0.5" 1313 | resolved "https://registry.yarnpkg.com/undefsafe/-/undefsafe-2.0.5.tgz#38733b9327bdcd226db889fb723a6efd162e6e2c" 1314 | integrity sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA== 1315 | 1316 | unpipe@1.0.0, unpipe@~1.0.0: 1317 | version "1.0.0" 1318 | resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" 1319 | integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== 1320 | 1321 | util-deprecate@^1.0.1, util-deprecate@~1.0.1: 1322 | version "1.0.2" 1323 | resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" 1324 | integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== 1325 | 1326 | utils-merge@1.0.1: 1327 | version "1.0.1" 1328 | resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" 1329 | integrity sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA== 1330 | 1331 | vary@~1.1.2: 1332 | version "1.1.2" 1333 | resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" 1334 | integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== 1335 | 1336 | webidl-conversions@^3.0.0: 1337 | version "3.0.1" 1338 | resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" 1339 | integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== 1340 | 1341 | whatwg-url@^5.0.0: 1342 | version "5.0.0" 1343 | resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" 1344 | integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== 1345 | dependencies: 1346 | tr46 "~0.0.3" 1347 | webidl-conversions "^3.0.0" 1348 | 1349 | wide-align@^1.1.2: 1350 | version "1.1.5" 1351 | resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.5.tgz#df1d4c206854369ecf3c9a4898f1b23fbd9d15d3" 1352 | integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== 1353 | dependencies: 1354 | string-width "^1.0.2 || 2 || 3 || 4" 1355 | 1356 | wrappy@1: 1357 | version "1.0.2" 1358 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 1359 | integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== 1360 | 1361 | xtend@^4.0.0: 1362 | version "4.0.2" 1363 | resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" 1364 | integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== 1365 | 1366 | yallist@^4.0.0: 1367 | version "4.0.0" 1368 | resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" 1369 | integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== 1370 | --------------------------------------------------------------------------------