├── .env.example ├── .eslintrc.json ├── .gitignore ├── README.md ├── middlewares ├── conectarMongoDB.ts ├── politicaCORS.ts └── validarTokenJWT.ts ├── models ├── PublicacaoModel.ts ├── SeguidorModel.ts └── UsuarioModel.ts ├── next-env.d.ts ├── next.config.js ├── package-lock.json ├── package.json ├── pages └── api │ ├── cadastro.ts │ ├── comentario.ts │ ├── feed.ts │ ├── like.ts │ ├── login.ts │ ├── pesquisa.ts │ ├── publicacao.ts │ ├── seguir.ts │ └── usuario.ts ├── services └── uploadImagemCosmic.ts ├── tsconfig.json └── types ├── CadastroRequisicao.ts ├── LoginResposta.ts └── RespostaPadraoMsg.ts /.env.example: -------------------------------------------------------------------------------- 1 | DB_CONEXAO_STRING= 2 | MINHA_CHAVE_JWT= 3 | CHAVE_GRAVACAO_AVATARES= 4 | CHAVE_GRAVACAO_PUBLICACOES= 5 | BUCKET_AVATARES= 6 | BUCKET_PUBLICACOES= -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "next/core-web-vitals" 3 | } 4 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | /node_modules 5 | /.pnp 6 | .pnp.js 7 | 8 | # testing 9 | /coverage 10 | 11 | # next.js 12 | /.next/ 13 | /out/ 14 | 15 | # production 16 | /build 17 | 18 | # misc 19 | .DS_Store 20 | *.pem 21 | 22 | # debug 23 | npm-debug.log* 24 | yarn-debug.log* 25 | yarn-error.log* 26 | 27 | # local env files 28 | .env.local 29 | .env.development.local 30 | .env.test.local 31 | .env.production.local 32 | 33 | # vercel 34 | .vercel 35 | 36 | # typescript 37 | *.tsbuildinfo 38 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app). 2 | 3 | ## Getting Started 4 | 5 | First, run the development server: 6 | 7 | ```bash 8 | npm run dev 9 | # or 10 | yarn dev 11 | ``` 12 | 13 | Open [http://localhost:3000](http://localhost:3000) with your browser to see the result. 14 | 15 | You can start editing the page by modifying `pages/index.tsx`. The page auto-updates as you edit the file. 16 | 17 | [API routes](https://nextjs.org/docs/api-routes/introduction) can be accessed on [http://localhost:3000/api/hello](http://localhost:3000/api/hello). This endpoint can be edited in `pages/api/hello.ts`. 18 | 19 | The `pages/api` directory is mapped to `/api/*`. Files in this directory are treated as [API routes](https://nextjs.org/docs/api-routes/introduction) instead of React pages. 20 | 21 | ## Learn More 22 | 23 | To learn more about Next.js, take a look at the following resources: 24 | 25 | - [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API. 26 | - [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial. 27 | 28 | You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome! 29 | 30 | ## Deploy on Vercel 31 | 32 | The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js. 33 | 34 | Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details. 35 | -------------------------------------------------------------------------------- /middlewares/conectarMongoDB.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse, NextApiHandler} from 'next'; 2 | import mongoose from 'mongoose'; 3 | import type {RespostaPadraoMsg} from '../types/RespostaPadraoMsg'; 4 | 5 | export const conectarMongoDB = (handler : NextApiHandler) => 6 | async (req: NextApiRequest, res : NextApiResponse) => { 7 | 8 | // verificar se o banco ja esta conectado, se estiver seguir 9 | // para o endpoint ou proximo middleware 10 | if(mongoose.connections[0].readyState){ 11 | return handler(req, res); 12 | } 13 | 14 | // ja que nao esta conectado vamos conectar 15 | // obter a variavel de ambiente preenchida do env 16 | const {DB_CONEXAO_STRING} = process.env; 17 | 18 | // se a env estiver vazia aborta o uso do sistema e avisa o programador 19 | if(!DB_CONEXAO_STRING){ 20 | return res.status(500).json({ erro : 'ENV de configuracao do banco, nao informado'}); 21 | } 22 | 23 | mongoose.connection.on('connected', () => console.log('Banco de dados conectado')); 24 | mongoose.connection.on('error', error => console.log(`Ocorreu erro ao conectar no banco: ${error}`)); 25 | await mongoose.connect(DB_CONEXAO_STRING); 26 | 27 | // agora posso seguir para o endpoint, pois estou conectado 28 | // no banco 29 | return handler(req, res); 30 | } -------------------------------------------------------------------------------- /middlewares/politicaCORS.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse, NextApiHandler} from 'next'; 2 | import type {RespostaPadraoMsg} from '../types/RespostaPadraoMsg'; 3 | import NextCors from 'nextjs-cors'; 4 | 5 | export const politicaCORS = (handler : NextApiHandler) => 6 | async (req : NextApiRequest, res : NextApiResponse) => { 7 | try{ 8 | await NextCors(req, res, { 9 | origin : '*', 10 | methods : ['GET', 'POST', 'PUT'], 11 | optionsSuccessStatus : 200, // navegadores antigos dao problema quando se retorna 204 12 | }); 13 | 14 | return handler(req, res); 15 | }catch(e){ 16 | console.log('Erro ao tratar a politica de CORS:', e); 17 | return res.status(500).json({erro : 'Ocorreu erro ao tratar a politica de CORS'}); 18 | } 19 | } -------------------------------------------------------------------------------- /middlewares/validarTokenJWT.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse, NextApiHandler} from 'next'; 2 | import type {RespostaPadraoMsg} from '../types/RespostaPadraoMsg'; 3 | import jwt, { JwtPayload } from 'jsonwebtoken'; 4 | 5 | export const validarTokenJWT = (handler : NextApiHandler) => 6 | (req : NextApiRequest, res : NextApiResponse) => { 7 | 8 | try{ 9 | const {MINHA_CHAVE_JWT} = process.env; 10 | if(!MINHA_CHAVE_JWT){ 11 | return res.status(500).json({ erro : 'ENV chave JWT nao inforada na execucao do projeto'}); 12 | } 13 | 14 | if(!req || !req.headers){ 15 | return res.status(401).json({erro: 'Nao foi possivel validar o token de acesso'}); 16 | } 17 | 18 | if(req.method !== 'OPTIONS'){ 19 | const authorization = req.headers['authorization']; 20 | if(!authorization){ 21 | return res.status(401).json({erro: 'Nao foi possivel validar o token de acesso'}); 22 | } 23 | 24 | const token = authorization.substring(7); 25 | if(!token){ 26 | return res.status(401).json({erro: 'Nao foi possivel validar o token de acesso'}); 27 | } 28 | 29 | const decoded = jwt.verify(token, MINHA_CHAVE_JWT) as JwtPayload; 30 | if(!decoded){ 31 | return res.status(401).json({erro: 'Nao foi possivel validar o token de acesso'}); 32 | } 33 | 34 | if(!req.query){ 35 | req.query = {}; 36 | } 37 | 38 | req.query.userId = decoded._id; 39 | } 40 | }catch(e){ 41 | console.log(e); 42 | return res.status(401).json({erro: 'Nao foi possivel validar o token de acesso'}); 43 | } 44 | 45 | return handler(req, res); 46 | } -------------------------------------------------------------------------------- /models/PublicacaoModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose, {Schema} from 'mongoose'; 2 | 3 | const PublicacaoSchema = new Schema({ 4 | idUsuario : {type : String, required : true}, 5 | descricao : {type : String, required : true}, 6 | foto : {type : String, required : true}, 7 | data : {type : Date, required : true}, 8 | comentarios : { type : Array, required : true, default : []}, 9 | likes : { type : Array, required : true, default : []}, 10 | }); 11 | 12 | export const PublicacaoModel = (mongoose.models.publicacoes || 13 | mongoose.model('publicacoes', PublicacaoSchema)); -------------------------------------------------------------------------------- /models/SeguidorModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose, {Schema} from 'mongoose'; 2 | 3 | const SeguidorSchema = new Schema({ 4 | // quem segue 5 | usuarioId : {type : String, required : true}, 6 | // quem esta sendo seguido 7 | usuarioSeguidoId : {type : String, required : true} 8 | }); 9 | 10 | export const SeguidorModel = (mongoose.models.seguidores || 11 | mongoose.model('seguidores', SeguidorSchema)); -------------------------------------------------------------------------------- /models/UsuarioModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose, {Schema} from 'mongoose'; 2 | 3 | const UsuarioSchema = new Schema({ 4 | nome: {type : String, required : true}, 5 | email: {type : String, required : true}, 6 | senha: {type : String, required : true}, 7 | avatar : {type : String, required : false}, 8 | seguidores : {type : Number, default : 0}, 9 | seguindo : {type : Number, default : 0}, 10 | publicacoes : {type : Number, default : 0}, 11 | }); 12 | 13 | export const UsuarioModel = (mongoose.models.usuarios || 14 | mongoose.model('usuarios', UsuarioSchema)); -------------------------------------------------------------------------------- /next-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | /// 3 | 4 | // NOTE: This file should not be edited 5 | // see https://nextjs.org/docs/basic-features/typescript for more information. 6 | -------------------------------------------------------------------------------- /next.config.js: -------------------------------------------------------------------------------- 1 | /** @type {import('next').NextConfig} */ 2 | const nextConfig = { 3 | reactStrictMode: true, 4 | typescript : { 5 | ignoreBuildErrors : true 6 | } 7 | } 8 | 9 | module.exports = nextConfig 10 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "devagram-node-nextjs", 3 | "requires": true, 4 | "lockfileVersion": 1, 5 | "dependencies": { 6 | "@babel/runtime": { 7 | "version": "7.17.2", 8 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.17.2.tgz", 9 | "integrity": "sha512-hzeyJyMA1YGdJTuWU0e/j4wKXrU4OMFvY2MSlaI9B7VQb0r5cxTE3EAIS2Q7Tn2RIcDkRvTA/v2JsAEhxe99uw==", 10 | "dev": true, 11 | "requires": { 12 | "regenerator-runtime": "^0.13.4" 13 | } 14 | }, 15 | "@babel/runtime-corejs3": { 16 | "version": "7.17.2", 17 | "resolved": "https://registry.npmjs.org/@babel/runtime-corejs3/-/runtime-corejs3-7.17.2.tgz", 18 | "integrity": "sha512-NcKtr2epxfIrNM4VOmPKO46TvDMCBhgi2CrSHaEarrz+Plk2K5r9QemmOFTGpZaoKnWoGH5MO+CzeRsih/Fcgg==", 19 | "dev": true, 20 | "requires": { 21 | "core-js-pure": "^3.20.2", 22 | "regenerator-runtime": "^0.13.4" 23 | } 24 | }, 25 | "@eslint/eslintrc": { 26 | "version": "1.0.5", 27 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.0.5.tgz", 28 | "integrity": "sha512-BLxsnmK3KyPunz5wmCCpqy0YelEoxxGmH73Is+Z74oOTMtExcjkr3dDR6quwrjh1YspA8DH9gnX1o069KiS9AQ==", 29 | "dev": true, 30 | "requires": { 31 | "ajv": "^6.12.4", 32 | "debug": "^4.3.2", 33 | "espree": "^9.2.0", 34 | "globals": "^13.9.0", 35 | "ignore": "^4.0.6", 36 | "import-fresh": "^3.2.1", 37 | "js-yaml": "^4.1.0", 38 | "minimatch": "^3.0.4", 39 | "strip-json-comments": "^3.1.1" 40 | }, 41 | "dependencies": { 42 | "ignore": { 43 | "version": "4.0.6", 44 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 45 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 46 | "dev": true 47 | } 48 | } 49 | }, 50 | "@humanwhocodes/config-array": { 51 | "version": "0.9.3", 52 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.3.tgz", 53 | "integrity": "sha512-3xSMlXHh03hCcCmFc0rbKp3Ivt2PFEJnQUJDDMTJQ2wkECZWdq4GePs2ctc5H8zV+cHPaq8k2vU8mrQjA6iHdQ==", 54 | "dev": true, 55 | "requires": { 56 | "@humanwhocodes/object-schema": "^1.2.1", 57 | "debug": "^4.1.1", 58 | "minimatch": "^3.0.4" 59 | } 60 | }, 61 | "@humanwhocodes/object-schema": { 62 | "version": "1.2.1", 63 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 64 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 65 | "dev": true 66 | }, 67 | "@next/env": { 68 | "version": "12.0.10", 69 | "resolved": "https://registry.npmjs.org/@next/env/-/env-12.0.10.tgz", 70 | "integrity": "sha512-mQVj0K6wQ5WEk/sL9SZ+mJXJUaG7el8CpZ6io1uFe9GgNTSC7EgUyNGqM6IQovIFc5ukF4O/hqsdh3S/DCgT2g==" 71 | }, 72 | "@next/eslint-plugin-next": { 73 | "version": "12.0.10", 74 | "resolved": "https://registry.npmjs.org/@next/eslint-plugin-next/-/eslint-plugin-next-12.0.10.tgz", 75 | "integrity": "sha512-PbGRnV5HGSfRGLjf8uTh1MaWgLwnjKjWiGVjK752ifITJbZ28/5AmLAFT2shDYeux8BHgpgVll5QXu7GN3YLFw==", 76 | "dev": true, 77 | "requires": { 78 | "glob": "7.1.7" 79 | }, 80 | "dependencies": { 81 | "glob": { 82 | "version": "7.1.7", 83 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 84 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 85 | "dev": true, 86 | "requires": { 87 | "fs.realpath": "^1.0.0", 88 | "inflight": "^1.0.4", 89 | "inherits": "2", 90 | "minimatch": "^3.0.4", 91 | "once": "^1.3.0", 92 | "path-is-absolute": "^1.0.0" 93 | } 94 | } 95 | } 96 | }, 97 | "@next/swc-android-arm64": { 98 | "version": "12.0.10", 99 | "resolved": "https://registry.npmjs.org/@next/swc-android-arm64/-/swc-android-arm64-12.0.10.tgz", 100 | "integrity": "sha512-xYwXGkNhzZZsM5MD7KRwF5ZNiC8OLPtVMUiagpPnwENg8Hb0GSQo/NbYWXM8YrawEwp9LaZ7OXiuRKPh2JyBdA==", 101 | "optional": true 102 | }, 103 | "@next/swc-darwin-arm64": { 104 | "version": "12.0.10", 105 | "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-12.0.10.tgz", 106 | "integrity": "sha512-f2zngulkpIJKWHckhRi7X8GZ+J/tNgFF7lYIh7Qx15JH0OTBsjkqxORlkzy+VZyHJ5sWTCaI6HYYd3ow6qkEEg==", 107 | "optional": true 108 | }, 109 | "@next/swc-darwin-x64": { 110 | "version": "12.0.10", 111 | "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-12.0.10.tgz", 112 | "integrity": "sha512-Qykcu/gVC5oTvOQoRBhyuS5GYm5SbcgrFTsaLFkGBmEkg9eMQRiaCswk4IafpDXVzITkVFurzSM28q3tLW2qUw==", 113 | "optional": true 114 | }, 115 | "@next/swc-linux-arm-gnueabihf": { 116 | "version": "12.0.10", 117 | "resolved": "https://registry.npmjs.org/@next/swc-linux-arm-gnueabihf/-/swc-linux-arm-gnueabihf-12.0.10.tgz", 118 | "integrity": "sha512-EhqrTFsIXAXN9B/fiiW/QKUK/lSLCXRsLalkUp58KDfMqVLLlj1ORbESAcswiNQOChLuHQSldGEEtOBPQZcd9A==", 119 | "optional": true 120 | }, 121 | "@next/swc-linux-arm64-gnu": { 122 | "version": "12.0.10", 123 | "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-12.0.10.tgz", 124 | "integrity": "sha512-kqGtC72g3+JYXZbY2ca6digXR5U6AQ6Dzv4eAxYluMePLHjI/Xye1mf9dwVsgmeXfrD/IRDp5K/3A6UNvBm4oQ==", 125 | "optional": true 126 | }, 127 | "@next/swc-linux-arm64-musl": { 128 | "version": "12.0.10", 129 | "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-12.0.10.tgz", 130 | "integrity": "sha512-bG9zTSNwnSgc1Un/7oz1ZVN4UeXsTWrsQhAGWU78lLLCn4Zj9HQoUCRCGLt0OVs2DBZ+WC8CzzFliQ1SKipVbg==", 131 | "optional": true 132 | }, 133 | "@next/swc-linux-x64-gnu": { 134 | "version": "12.0.10", 135 | "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-12.0.10.tgz", 136 | "integrity": "sha512-c79PcfWtyThiYRa1+3KVfDq0zXaI8o1d6dQWNVqDrtLz5HKM/rbjLdvoNuxDwUeZhxI/d9CtyH6GbuKPw5l/5A==", 137 | "optional": true 138 | }, 139 | "@next/swc-linux-x64-musl": { 140 | "version": "12.0.10", 141 | "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-12.0.10.tgz", 142 | "integrity": "sha512-g/scgn+21/MLfizOCZOZt+MxNj2/8Tdlwjvy+QZcSUPZRUI2Y5o3HwBvI1f/bSci+NGRU+bUAO0NFtRJ9MzH5w==", 143 | "optional": true 144 | }, 145 | "@next/swc-win32-arm64-msvc": { 146 | "version": "12.0.10", 147 | "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-12.0.10.tgz", 148 | "integrity": "sha512-gl6B/ravwMeY5Nv4Il2/ARYJQ6u+KPRwGMjS1ZrNudIKlNn4YBeXh5A4cIVm+dHaff6/O/lGOa5/SUYDMZpkww==", 149 | "optional": true 150 | }, 151 | "@next/swc-win32-ia32-msvc": { 152 | "version": "12.0.10", 153 | "resolved": "https://registry.npmjs.org/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-12.0.10.tgz", 154 | "integrity": "sha512-7RVpZ3tSThC6j+iZB0CUYmFiA3kXmN+pE7QcfyAxFaflKlaZoWNMKHIEZDuxSJc6YmQ6kyxsjqxVay2F5+/YCg==", 155 | "optional": true 156 | }, 157 | "@next/swc-win32-x64-msvc": { 158 | "version": "12.0.10", 159 | "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-12.0.10.tgz", 160 | "integrity": "sha512-oUIWRKd24jFLRWUYO1CZmML5+32BcpVfqhimGaaZIXcOkfQW+iqiAzdqsv688zaGtyKGeB9ZtiK3NDf+Q0v+Vw==", 161 | "optional": true 162 | }, 163 | "@nodelib/fs.scandir": { 164 | "version": "2.1.5", 165 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 166 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 167 | "dev": true, 168 | "requires": { 169 | "@nodelib/fs.stat": "2.0.5", 170 | "run-parallel": "^1.1.9" 171 | } 172 | }, 173 | "@nodelib/fs.stat": { 174 | "version": "2.0.5", 175 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 176 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 177 | "dev": true 178 | }, 179 | "@nodelib/fs.walk": { 180 | "version": "1.2.8", 181 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 182 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 183 | "dev": true, 184 | "requires": { 185 | "@nodelib/fs.scandir": "2.1.5", 186 | "fastq": "^1.6.0" 187 | } 188 | }, 189 | "@rushstack/eslint-patch": { 190 | "version": "1.1.0", 191 | "resolved": "https://registry.npmjs.org/@rushstack/eslint-patch/-/eslint-patch-1.1.0.tgz", 192 | "integrity": "sha512-JLo+Y592QzIE+q7Dl2pMUtt4q8SKYI5jDrZxrozEQxnGVOyYE+GWK9eLkwTaeN9DDctlaRAQ3TBmzZ1qdLE30A==", 193 | "dev": true 194 | }, 195 | "@types/body-parser": { 196 | "version": "1.19.2", 197 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 198 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 199 | "dev": true, 200 | "requires": { 201 | "@types/connect": "*", 202 | "@types/node": "*" 203 | } 204 | }, 205 | "@types/connect": { 206 | "version": "3.4.35", 207 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 208 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 209 | "dev": true, 210 | "requires": { 211 | "@types/node": "*" 212 | } 213 | }, 214 | "@types/express": { 215 | "version": "4.17.13", 216 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 217 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 218 | "dev": true, 219 | "requires": { 220 | "@types/body-parser": "*", 221 | "@types/express-serve-static-core": "^4.17.18", 222 | "@types/qs": "*", 223 | "@types/serve-static": "*" 224 | } 225 | }, 226 | "@types/express-serve-static-core": { 227 | "version": "4.17.28", 228 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.28.tgz", 229 | "integrity": "sha512-P1BJAEAW3E2DJUlkgq4tOL3RyMunoWXqbSCygWo5ZIWTjUgN1YnaXWW4VWl/oc8vs/XoYibEGBKP0uZyF4AHig==", 230 | "dev": true, 231 | "requires": { 232 | "@types/node": "*", 233 | "@types/qs": "*", 234 | "@types/range-parser": "*" 235 | } 236 | }, 237 | "@types/json5": { 238 | "version": "0.0.29", 239 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 240 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 241 | "dev": true 242 | }, 243 | "@types/jsonwebtoken": { 244 | "version": "8.5.8", 245 | "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.8.tgz", 246 | "integrity": "sha512-zm6xBQpFDIDM6o9r6HSgDeIcLy82TKWctCXEPbJJcXb5AKmi5BNNdLXneixK4lplX3PqIVcwLBCGE/kAGnlD4A==", 247 | "dev": true, 248 | "requires": { 249 | "@types/node": "*" 250 | } 251 | }, 252 | "@types/md5": { 253 | "version": "2.3.2", 254 | "resolved": "https://registry.npmjs.org/@types/md5/-/md5-2.3.2.tgz", 255 | "integrity": "sha512-v+JFDu96+UYJ3/UWzB0mEglIS//MZXgRaJ4ubUPwOM0gvLc/kcQ3TWNYwENEK7/EcXGQVrW8h/XqednSjBd/Og==", 256 | "dev": true 257 | }, 258 | "@types/mime": { 259 | "version": "1.3.2", 260 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 261 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 262 | "dev": true 263 | }, 264 | "@types/multer": { 265 | "version": "1.4.7", 266 | "resolved": "https://registry.npmjs.org/@types/multer/-/multer-1.4.7.tgz", 267 | "integrity": "sha512-/SNsDidUFCvqqcWDwxv2feww/yqhNeTRL5CVoL3jU4Goc4kKEL10T7Eye65ZqPNi4HRx8sAEX59pV1aEH7drNA==", 268 | "dev": true, 269 | "requires": { 270 | "@types/express": "*" 271 | } 272 | }, 273 | "@types/node": { 274 | "version": "17.0.16", 275 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.16.tgz", 276 | "integrity": "sha512-ydLaGVfQOQ6hI1xK2A5nVh8bl0OGoIfYMxPWHqqYe9bTkWCfqiVvZoh2I/QF2sNSkZzZyROBoTefIEI+PB6iIA==" 277 | }, 278 | "@types/prop-types": { 279 | "version": "15.7.4", 280 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.4.tgz", 281 | "integrity": "sha512-rZ5drC/jWjrArrS8BR6SIr4cWpW09RNTYt9AMZo3Jwwif+iacXAqgVjm0B0Bv/S1jhDXKHqRVNCbACkJ89RAnQ==", 282 | "dev": true 283 | }, 284 | "@types/qs": { 285 | "version": "6.9.7", 286 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 287 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 288 | "dev": true 289 | }, 290 | "@types/range-parser": { 291 | "version": "1.2.4", 292 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 293 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 294 | "dev": true 295 | }, 296 | "@types/react": { 297 | "version": "17.0.39", 298 | "resolved": "https://registry.npmjs.org/@types/react/-/react-17.0.39.tgz", 299 | "integrity": "sha512-UVavlfAxDd/AgAacMa60Azl7ygyQNRwC/DsHZmKgNvPmRR5p70AJ5Q9EAmL2NWOJmeV+vVUI4IAP7GZrN8h8Ug==", 300 | "dev": true, 301 | "requires": { 302 | "@types/prop-types": "*", 303 | "@types/scheduler": "*", 304 | "csstype": "^3.0.2" 305 | } 306 | }, 307 | "@types/scheduler": { 308 | "version": "0.16.2", 309 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", 310 | "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==", 311 | "dev": true 312 | }, 313 | "@types/serve-static": { 314 | "version": "1.13.10", 315 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 316 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 317 | "dev": true, 318 | "requires": { 319 | "@types/mime": "^1", 320 | "@types/node": "*" 321 | } 322 | }, 323 | "@types/webidl-conversions": { 324 | "version": "6.1.1", 325 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-6.1.1.tgz", 326 | "integrity": "sha512-XAahCdThVuCFDQLT7R7Pk/vqeObFNL3YqRyFZg+AqAP/W1/w3xHaIxuW7WszQqTbIBOPRcItYJIou3i/mppu3Q==" 327 | }, 328 | "@types/whatwg-url": { 329 | "version": "8.2.1", 330 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.1.tgz", 331 | "integrity": "sha512-2YubE1sjj5ifxievI5Ge1sckb9k/Er66HyR2c+3+I6VDUUg1TLPdYYTEbQ+DjRkS4nTxMJhgWfSfMRD2sl2EYQ==", 332 | "requires": { 333 | "@types/node": "*", 334 | "@types/webidl-conversions": "*" 335 | } 336 | }, 337 | "@typescript-eslint/parser": { 338 | "version": "5.11.0", 339 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.11.0.tgz", 340 | "integrity": "sha512-x0DCjetHZYBRovJdr3U0zG9OOdNXUaFLJ82ehr1AlkArljJuwEsgnud+Q7umlGDFLFrs8tU8ybQDFocp/eX8mQ==", 341 | "dev": true, 342 | "requires": { 343 | "@typescript-eslint/scope-manager": "5.11.0", 344 | "@typescript-eslint/types": "5.11.0", 345 | "@typescript-eslint/typescript-estree": "5.11.0", 346 | "debug": "^4.3.2" 347 | } 348 | }, 349 | "@typescript-eslint/scope-manager": { 350 | "version": "5.11.0", 351 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.11.0.tgz", 352 | "integrity": "sha512-z+K4LlahDFVMww20t/0zcA7gq/NgOawaLuxgqGRVKS0PiZlCTIUtX0EJbC0BK1JtR4CelmkPK67zuCgpdlF4EA==", 353 | "dev": true, 354 | "requires": { 355 | "@typescript-eslint/types": "5.11.0", 356 | "@typescript-eslint/visitor-keys": "5.11.0" 357 | } 358 | }, 359 | "@typescript-eslint/types": { 360 | "version": "5.11.0", 361 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.11.0.tgz", 362 | "integrity": "sha512-cxgBFGSRCoBEhvSVLkKw39+kMzUKHlJGVwwMbPcTZX3qEhuXhrjwaZXWMxVfxDgyMm+b5Q5b29Llo2yow8Y7xQ==", 363 | "dev": true 364 | }, 365 | "@typescript-eslint/typescript-estree": { 366 | "version": "5.11.0", 367 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.11.0.tgz", 368 | "integrity": "sha512-yVH9hKIv3ZN3lw8m/Jy5I4oXO4ZBMqijcXCdA4mY8ull6TPTAoQnKKrcZ0HDXg7Bsl0Unwwx7jcXMuNZc0m4lg==", 369 | "dev": true, 370 | "requires": { 371 | "@typescript-eslint/types": "5.11.0", 372 | "@typescript-eslint/visitor-keys": "5.11.0", 373 | "debug": "^4.3.2", 374 | "globby": "^11.0.4", 375 | "is-glob": "^4.0.3", 376 | "semver": "^7.3.5", 377 | "tsutils": "^3.21.0" 378 | } 379 | }, 380 | "@typescript-eslint/visitor-keys": { 381 | "version": "5.11.0", 382 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.11.0.tgz", 383 | "integrity": "sha512-E8w/vJReMGuloGxJDkpPlGwhxocxOpSVgSvjiLO5IxZPmxZF30weOeJYyPSEACwM+X4NziYS9q+WkN/2DHYQwA==", 384 | "dev": true, 385 | "requires": { 386 | "@typescript-eslint/types": "5.11.0", 387 | "eslint-visitor-keys": "^3.0.0" 388 | } 389 | }, 390 | "acorn": { 391 | "version": "8.7.0", 392 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 393 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", 394 | "dev": true 395 | }, 396 | "acorn-jsx": { 397 | "version": "5.3.2", 398 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 399 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 400 | "dev": true 401 | }, 402 | "ajv": { 403 | "version": "6.12.6", 404 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 405 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 406 | "dev": true, 407 | "requires": { 408 | "fast-deep-equal": "^3.1.1", 409 | "fast-json-stable-stringify": "^2.0.0", 410 | "json-schema-traverse": "^0.4.1", 411 | "uri-js": "^4.2.2" 412 | } 413 | }, 414 | "ansi-regex": { 415 | "version": "5.0.1", 416 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 417 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 418 | "dev": true 419 | }, 420 | "ansi-styles": { 421 | "version": "4.3.0", 422 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 423 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 424 | "dev": true, 425 | "requires": { 426 | "color-convert": "^2.0.1" 427 | } 428 | }, 429 | "append-field": { 430 | "version": "1.0.0", 431 | "resolved": "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz", 432 | "integrity": "sha1-HjRA6RXwsSA9I3SOeO3XubW0PlY=" 433 | }, 434 | "argparse": { 435 | "version": "2.0.1", 436 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 437 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 438 | "dev": true 439 | }, 440 | "aria-query": { 441 | "version": "4.2.2", 442 | "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-4.2.2.tgz", 443 | "integrity": "sha512-o/HelwhuKpTj/frsOsbNLNgnNGVIFsVP/SW2BSF14gVl7kAfMOJ6/8wUAUvG1R1NHKrfG+2sHZTu0yauT1qBrA==", 444 | "dev": true, 445 | "requires": { 446 | "@babel/runtime": "^7.10.2", 447 | "@babel/runtime-corejs3": "^7.10.2" 448 | } 449 | }, 450 | "array-includes": { 451 | "version": "3.1.4", 452 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.4.tgz", 453 | "integrity": "sha512-ZTNSQkmWumEbiHO2GF4GmWxYVTiQyJy2XOTa15sdQSrvKn7l+180egQMqlrMOUMCyLMD7pmyQe4mMDUT6Behrw==", 454 | "dev": true, 455 | "requires": { 456 | "call-bind": "^1.0.2", 457 | "define-properties": "^1.1.3", 458 | "es-abstract": "^1.19.1", 459 | "get-intrinsic": "^1.1.1", 460 | "is-string": "^1.0.7" 461 | } 462 | }, 463 | "array-union": { 464 | "version": "2.1.0", 465 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 466 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 467 | "dev": true 468 | }, 469 | "array.prototype.flat": { 470 | "version": "1.2.5", 471 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.5.tgz", 472 | "integrity": "sha512-KaYU+S+ndVqyUnignHftkwc58o3uVU1jzczILJ1tN2YaIZpFIKBiP/x/j97E5MVPsaCloPbqWLB/8qCTVvT2qg==", 473 | "dev": true, 474 | "requires": { 475 | "call-bind": "^1.0.2", 476 | "define-properties": "^1.1.3", 477 | "es-abstract": "^1.19.0" 478 | } 479 | }, 480 | "array.prototype.flatmap": { 481 | "version": "1.2.5", 482 | "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.2.5.tgz", 483 | "integrity": "sha512-08u6rVyi1Lj7oqWbS9nUxliETrtIROT4XGTA4D/LWGten6E3ocm7cy9SIrmNHOL5XVbVuckUp3X6Xyg8/zpvHA==", 484 | "dev": true, 485 | "requires": { 486 | "call-bind": "^1.0.0", 487 | "define-properties": "^1.1.3", 488 | "es-abstract": "^1.19.0" 489 | } 490 | }, 491 | "ast-types-flow": { 492 | "version": "0.0.7", 493 | "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.7.tgz", 494 | "integrity": "sha1-9wtzXGvKGlycItmCw+Oef+ujva0=", 495 | "dev": true 496 | }, 497 | "asynckit": { 498 | "version": "0.4.0", 499 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 500 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 501 | }, 502 | "axe-core": { 503 | "version": "4.4.1", 504 | "resolved": "https://registry.npmjs.org/axe-core/-/axe-core-4.4.1.tgz", 505 | "integrity": "sha512-gd1kmb21kwNuWr6BQz8fv6GNECPBnUasepcoLbekws23NVBLODdsClRZ+bQ8+9Uomf3Sm3+Vwn0oYG9NvwnJCw==", 506 | "dev": true 507 | }, 508 | "axios": { 509 | "version": "0.21.4", 510 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.4.tgz", 511 | "integrity": "sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg==", 512 | "requires": { 513 | "follow-redirects": "^1.14.0" 514 | } 515 | }, 516 | "axobject-query": { 517 | "version": "2.2.0", 518 | "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-2.2.0.tgz", 519 | "integrity": "sha512-Td525n+iPOOyUQIeBfcASuG6uJsDOITl7Mds5gFyerkWiX7qhUTdYUBlSgNMyVqtSJqwpt1kXGLdUt6SykLMRA==", 520 | "dev": true 521 | }, 522 | "balanced-match": { 523 | "version": "1.0.2", 524 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 525 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 526 | "dev": true 527 | }, 528 | "base64-js": { 529 | "version": "1.5.1", 530 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 531 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==" 532 | }, 533 | "brace-expansion": { 534 | "version": "1.1.11", 535 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 536 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 537 | "dev": true, 538 | "requires": { 539 | "balanced-match": "^1.0.0", 540 | "concat-map": "0.0.1" 541 | } 542 | }, 543 | "braces": { 544 | "version": "3.0.2", 545 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 546 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 547 | "dev": true, 548 | "requires": { 549 | "fill-range": "^7.0.1" 550 | } 551 | }, 552 | "bson": { 553 | "version": "4.6.1", 554 | "resolved": "https://registry.npmjs.org/bson/-/bson-4.6.1.tgz", 555 | "integrity": "sha512-I1LQ7Hz5zgwR4QquilLNZwbhPw0Apx7i7X9kGMBTsqPdml/03Q9NBtD9nt/19ahjlphktQImrnderxqpzeVDjw==", 556 | "requires": { 557 | "buffer": "^5.6.0" 558 | } 559 | }, 560 | "buffer": { 561 | "version": "5.7.1", 562 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 563 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 564 | "requires": { 565 | "base64-js": "^1.3.1", 566 | "ieee754": "^1.1.13" 567 | } 568 | }, 569 | "buffer-equal-constant-time": { 570 | "version": "1.0.1", 571 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 572 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 573 | }, 574 | "buffer-from": { 575 | "version": "1.1.2", 576 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 577 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" 578 | }, 579 | "busboy": { 580 | "version": "0.2.14", 581 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-0.2.14.tgz", 582 | "integrity": "sha1-bCpiLvz0fFe7vh4qnDetNseSVFM=", 583 | "requires": { 584 | "dicer": "0.2.5", 585 | "readable-stream": "1.1.x" 586 | } 587 | }, 588 | "call-bind": { 589 | "version": "1.0.2", 590 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 591 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 592 | "dev": true, 593 | "requires": { 594 | "function-bind": "^1.1.1", 595 | "get-intrinsic": "^1.0.2" 596 | } 597 | }, 598 | "callsites": { 599 | "version": "3.1.0", 600 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 601 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 602 | "dev": true 603 | }, 604 | "caniuse-lite": { 605 | "version": "1.0.30001310", 606 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001310.tgz", 607 | "integrity": "sha512-cb9xTV8k9HTIUA3GnPUJCk0meUnrHL5gy5QePfDjxHyNBcnzPzrHFv5GqfP7ue5b1ZyzZL0RJboD6hQlPXjhjg==" 608 | }, 609 | "chalk": { 610 | "version": "4.1.2", 611 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 612 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 613 | "dev": true, 614 | "requires": { 615 | "ansi-styles": "^4.1.0", 616 | "supports-color": "^7.1.0" 617 | } 618 | }, 619 | "charenc": { 620 | "version": "0.0.2", 621 | "resolved": "https://registry.npmjs.org/charenc/-/charenc-0.0.2.tgz", 622 | "integrity": "sha1-wKHS86cJLgN3S/qD8UwPxXkKhmc=" 623 | }, 624 | "color-convert": { 625 | "version": "2.0.1", 626 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 627 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 628 | "dev": true, 629 | "requires": { 630 | "color-name": "~1.1.4" 631 | } 632 | }, 633 | "color-name": { 634 | "version": "1.1.4", 635 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 636 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 637 | "dev": true 638 | }, 639 | "combined-stream": { 640 | "version": "1.0.8", 641 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 642 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 643 | "requires": { 644 | "delayed-stream": "~1.0.0" 645 | } 646 | }, 647 | "concat-map": { 648 | "version": "0.0.1", 649 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 650 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 651 | "dev": true 652 | }, 653 | "concat-stream": { 654 | "version": "1.6.2", 655 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 656 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 657 | "requires": { 658 | "buffer-from": "^1.0.0", 659 | "inherits": "^2.0.3", 660 | "readable-stream": "^2.2.2", 661 | "typedarray": "^0.0.6" 662 | }, 663 | "dependencies": { 664 | "isarray": { 665 | "version": "1.0.0", 666 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 667 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 668 | }, 669 | "readable-stream": { 670 | "version": "2.3.7", 671 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 672 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 673 | "requires": { 674 | "core-util-is": "~1.0.0", 675 | "inherits": "~2.0.3", 676 | "isarray": "~1.0.0", 677 | "process-nextick-args": "~2.0.0", 678 | "safe-buffer": "~5.1.1", 679 | "string_decoder": "~1.1.1", 680 | "util-deprecate": "~1.0.1" 681 | } 682 | }, 683 | "safe-buffer": { 684 | "version": "5.1.2", 685 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 686 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 687 | }, 688 | "string_decoder": { 689 | "version": "1.1.1", 690 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 691 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 692 | "requires": { 693 | "safe-buffer": "~5.1.0" 694 | } 695 | } 696 | } 697 | }, 698 | "core-js-pure": { 699 | "version": "3.21.0", 700 | "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.21.0.tgz", 701 | "integrity": "sha512-VaJUunCZLnxuDbo1rNOzwbet9E1K9joiXS5+DQMPtgxd24wfsZbJZMMfQLGYMlCUvSxLfsRUUhoOR2x28mFfeg==", 702 | "dev": true 703 | }, 704 | "core-util-is": { 705 | "version": "1.0.3", 706 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 707 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" 708 | }, 709 | "cors": { 710 | "version": "2.8.5", 711 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 712 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 713 | "requires": { 714 | "object-assign": "^4", 715 | "vary": "^1" 716 | } 717 | }, 718 | "cosmicjs": { 719 | "version": "4.1.2", 720 | "resolved": "https://registry.npmjs.org/cosmicjs/-/cosmicjs-4.1.2.tgz", 721 | "integrity": "sha512-ngTcxWVkZ3h2G8MDosGHcss9Akzj0l+cyJ6h4aPWTqSlF0Yn5PaprBjv/mJVtwysCJjDgwYkXZTAtgADkPcj8w==", 722 | "requires": { 723 | "axios": "^0.21.1", 724 | "form-data": "^3.0.0" 725 | } 726 | }, 727 | "cross-spawn": { 728 | "version": "7.0.3", 729 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 730 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 731 | "dev": true, 732 | "requires": { 733 | "path-key": "^3.1.0", 734 | "shebang-command": "^2.0.0", 735 | "which": "^2.0.1" 736 | } 737 | }, 738 | "crypt": { 739 | "version": "0.0.2", 740 | "resolved": "https://registry.npmjs.org/crypt/-/crypt-0.0.2.tgz", 741 | "integrity": "sha1-iNf/fsDfuG9xPch7u0LQRNPmxBs=" 742 | }, 743 | "csstype": { 744 | "version": "3.0.10", 745 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.0.10.tgz", 746 | "integrity": "sha512-2u44ZG2OcNUO9HDp/Jl8C07x6pU/eTR3ncV91SiK3dhG9TWvRVsCoJw14Ckx5DgWkzGA3waZWO3d7pgqpUI/XA==", 747 | "dev": true 748 | }, 749 | "damerau-levenshtein": { 750 | "version": "1.0.8", 751 | "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz", 752 | "integrity": "sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA==", 753 | "dev": true 754 | }, 755 | "debug": { 756 | "version": "4.3.3", 757 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 758 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 759 | "requires": { 760 | "ms": "2.1.2" 761 | } 762 | }, 763 | "deep-is": { 764 | "version": "0.1.4", 765 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 766 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 767 | "dev": true 768 | }, 769 | "define-properties": { 770 | "version": "1.1.3", 771 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 772 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 773 | "dev": true, 774 | "requires": { 775 | "object-keys": "^1.0.12" 776 | } 777 | }, 778 | "delayed-stream": { 779 | "version": "1.0.0", 780 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 781 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 782 | }, 783 | "denque": { 784 | "version": "2.0.1", 785 | "resolved": "https://registry.npmjs.org/denque/-/denque-2.0.1.tgz", 786 | "integrity": "sha512-tfiWc6BQLXNLpNiR5iGd0Ocu3P3VpxfzFiqubLgMfhfOw9WyvgJBd46CClNn9k3qfbjvT//0cf7AlYRX/OslMQ==" 787 | }, 788 | "dicer": { 789 | "version": "0.2.5", 790 | "resolved": "https://registry.npmjs.org/dicer/-/dicer-0.2.5.tgz", 791 | "integrity": "sha1-WZbAhrszIYyBLAkL3cCc0S+stw8=", 792 | "requires": { 793 | "readable-stream": "1.1.x", 794 | "streamsearch": "0.1.2" 795 | } 796 | }, 797 | "dir-glob": { 798 | "version": "3.0.1", 799 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 800 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 801 | "dev": true, 802 | "requires": { 803 | "path-type": "^4.0.0" 804 | } 805 | }, 806 | "doctrine": { 807 | "version": "3.0.0", 808 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 809 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 810 | "dev": true, 811 | "requires": { 812 | "esutils": "^2.0.2" 813 | } 814 | }, 815 | "ecdsa-sig-formatter": { 816 | "version": "1.0.11", 817 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 818 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 819 | "requires": { 820 | "safe-buffer": "^5.0.1" 821 | } 822 | }, 823 | "ee-first": { 824 | "version": "1.1.1", 825 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 826 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 827 | }, 828 | "emoji-regex": { 829 | "version": "9.2.2", 830 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 831 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 832 | "dev": true 833 | }, 834 | "es-abstract": { 835 | "version": "1.19.1", 836 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.1.tgz", 837 | "integrity": "sha512-2vJ6tjA/UfqLm2MPs7jxVybLoB8i1t1Jd9R3kISld20sIxPcTbLuggQOUxeWeAvIUkduv/CfMjuh4WmiXr2v9w==", 838 | "dev": true, 839 | "requires": { 840 | "call-bind": "^1.0.2", 841 | "es-to-primitive": "^1.2.1", 842 | "function-bind": "^1.1.1", 843 | "get-intrinsic": "^1.1.1", 844 | "get-symbol-description": "^1.0.0", 845 | "has": "^1.0.3", 846 | "has-symbols": "^1.0.2", 847 | "internal-slot": "^1.0.3", 848 | "is-callable": "^1.2.4", 849 | "is-negative-zero": "^2.0.1", 850 | "is-regex": "^1.1.4", 851 | "is-shared-array-buffer": "^1.0.1", 852 | "is-string": "^1.0.7", 853 | "is-weakref": "^1.0.1", 854 | "object-inspect": "^1.11.0", 855 | "object-keys": "^1.1.1", 856 | "object.assign": "^4.1.2", 857 | "string.prototype.trimend": "^1.0.4", 858 | "string.prototype.trimstart": "^1.0.4", 859 | "unbox-primitive": "^1.0.1" 860 | } 861 | }, 862 | "es-to-primitive": { 863 | "version": "1.2.1", 864 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 865 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 866 | "dev": true, 867 | "requires": { 868 | "is-callable": "^1.1.4", 869 | "is-date-object": "^1.0.1", 870 | "is-symbol": "^1.0.2" 871 | } 872 | }, 873 | "escape-string-regexp": { 874 | "version": "4.0.0", 875 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 876 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 877 | "dev": true 878 | }, 879 | "eslint": { 880 | "version": "8.8.0", 881 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.8.0.tgz", 882 | "integrity": "sha512-H3KXAzQGBH1plhYS3okDix2ZthuYJlQQEGE5k0IKuEqUSiyu4AmxxlJ2MtTYeJ3xB4jDhcYCwGOg2TXYdnDXlQ==", 883 | "dev": true, 884 | "requires": { 885 | "@eslint/eslintrc": "^1.0.5", 886 | "@humanwhocodes/config-array": "^0.9.2", 887 | "ajv": "^6.10.0", 888 | "chalk": "^4.0.0", 889 | "cross-spawn": "^7.0.2", 890 | "debug": "^4.3.2", 891 | "doctrine": "^3.0.0", 892 | "escape-string-regexp": "^4.0.0", 893 | "eslint-scope": "^7.1.0", 894 | "eslint-utils": "^3.0.0", 895 | "eslint-visitor-keys": "^3.2.0", 896 | "espree": "^9.3.0", 897 | "esquery": "^1.4.0", 898 | "esutils": "^2.0.2", 899 | "fast-deep-equal": "^3.1.3", 900 | "file-entry-cache": "^6.0.1", 901 | "functional-red-black-tree": "^1.0.1", 902 | "glob-parent": "^6.0.1", 903 | "globals": "^13.6.0", 904 | "ignore": "^5.2.0", 905 | "import-fresh": "^3.0.0", 906 | "imurmurhash": "^0.1.4", 907 | "is-glob": "^4.0.0", 908 | "js-yaml": "^4.1.0", 909 | "json-stable-stringify-without-jsonify": "^1.0.1", 910 | "levn": "^0.4.1", 911 | "lodash.merge": "^4.6.2", 912 | "minimatch": "^3.0.4", 913 | "natural-compare": "^1.4.0", 914 | "optionator": "^0.9.1", 915 | "regexpp": "^3.2.0", 916 | "strip-ansi": "^6.0.1", 917 | "strip-json-comments": "^3.1.0", 918 | "text-table": "^0.2.0", 919 | "v8-compile-cache": "^2.0.3" 920 | } 921 | }, 922 | "eslint-config-next": { 923 | "version": "12.0.10", 924 | "resolved": "https://registry.npmjs.org/eslint-config-next/-/eslint-config-next-12.0.10.tgz", 925 | "integrity": "sha512-l1er6mwSo1bltjLwmd71p5BdT6k/NQxV1n4lKZI6xt3MDMrq7ChUBr+EecxOry8GC/rCRUtPpH8Ygs0BJc5YLg==", 926 | "dev": true, 927 | "requires": { 928 | "@next/eslint-plugin-next": "12.0.10", 929 | "@rushstack/eslint-patch": "^1.0.8", 930 | "@typescript-eslint/parser": "^5.0.0", 931 | "eslint-import-resolver-node": "^0.3.4", 932 | "eslint-import-resolver-typescript": "^2.4.0", 933 | "eslint-plugin-import": "^2.25.2", 934 | "eslint-plugin-jsx-a11y": "^6.5.1", 935 | "eslint-plugin-react": "^7.27.0", 936 | "eslint-plugin-react-hooks": "^4.3.0" 937 | } 938 | }, 939 | "eslint-import-resolver-node": { 940 | "version": "0.3.6", 941 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.6.tgz", 942 | "integrity": "sha512-0En0w03NRVMn9Uiyn8YRPDKvWjxCWkslUEhGNTdGx15RvPJYQ+lbOlqrlNI2vEAs4pDYK4f/HN2TbDmk5TP0iw==", 943 | "dev": true, 944 | "requires": { 945 | "debug": "^3.2.7", 946 | "resolve": "^1.20.0" 947 | }, 948 | "dependencies": { 949 | "debug": { 950 | "version": "3.2.7", 951 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 952 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 953 | "dev": true, 954 | "requires": { 955 | "ms": "^2.1.1" 956 | } 957 | } 958 | } 959 | }, 960 | "eslint-import-resolver-typescript": { 961 | "version": "2.5.0", 962 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-typescript/-/eslint-import-resolver-typescript-2.5.0.tgz", 963 | "integrity": "sha512-qZ6e5CFr+I7K4VVhQu3M/9xGv9/YmwsEXrsm3nimw8vWaVHRDrQRp26BgCypTxBp3vUp4o5aVEJRiy0F2DFddQ==", 964 | "dev": true, 965 | "requires": { 966 | "debug": "^4.3.1", 967 | "glob": "^7.1.7", 968 | "is-glob": "^4.0.1", 969 | "resolve": "^1.20.0", 970 | "tsconfig-paths": "^3.9.0" 971 | } 972 | }, 973 | "eslint-module-utils": { 974 | "version": "2.7.3", 975 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.7.3.tgz", 976 | "integrity": "sha512-088JEC7O3lDZM9xGe0RerkOMd0EjFl+Yvd1jPWIkMT5u3H9+HC34mWWPnqPrN13gieT9pBOO+Qt07Nb/6TresQ==", 977 | "dev": true, 978 | "requires": { 979 | "debug": "^3.2.7", 980 | "find-up": "^2.1.0" 981 | }, 982 | "dependencies": { 983 | "debug": { 984 | "version": "3.2.7", 985 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 986 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 987 | "dev": true, 988 | "requires": { 989 | "ms": "^2.1.1" 990 | } 991 | } 992 | } 993 | }, 994 | "eslint-plugin-import": { 995 | "version": "2.25.4", 996 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.25.4.tgz", 997 | "integrity": "sha512-/KJBASVFxpu0xg1kIBn9AUa8hQVnszpwgE7Ld0lKAlx7Ie87yzEzCgSkekt+le/YVhiaosO4Y14GDAOc41nfxA==", 998 | "dev": true, 999 | "requires": { 1000 | "array-includes": "^3.1.4", 1001 | "array.prototype.flat": "^1.2.5", 1002 | "debug": "^2.6.9", 1003 | "doctrine": "^2.1.0", 1004 | "eslint-import-resolver-node": "^0.3.6", 1005 | "eslint-module-utils": "^2.7.2", 1006 | "has": "^1.0.3", 1007 | "is-core-module": "^2.8.0", 1008 | "is-glob": "^4.0.3", 1009 | "minimatch": "^3.0.4", 1010 | "object.values": "^1.1.5", 1011 | "resolve": "^1.20.0", 1012 | "tsconfig-paths": "^3.12.0" 1013 | }, 1014 | "dependencies": { 1015 | "debug": { 1016 | "version": "2.6.9", 1017 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1018 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1019 | "dev": true, 1020 | "requires": { 1021 | "ms": "2.0.0" 1022 | } 1023 | }, 1024 | "doctrine": { 1025 | "version": "2.1.0", 1026 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1027 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1028 | "dev": true, 1029 | "requires": { 1030 | "esutils": "^2.0.2" 1031 | } 1032 | }, 1033 | "ms": { 1034 | "version": "2.0.0", 1035 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1036 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1037 | "dev": true 1038 | } 1039 | } 1040 | }, 1041 | "eslint-plugin-jsx-a11y": { 1042 | "version": "6.5.1", 1043 | "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.5.1.tgz", 1044 | "integrity": "sha512-sVCFKX9fllURnXT2JwLN5Qgo24Ug5NF6dxhkmxsMEUZhXRcGg+X3e1JbJ84YePQKBl5E0ZjAH5Q4rkdcGY99+g==", 1045 | "dev": true, 1046 | "requires": { 1047 | "@babel/runtime": "^7.16.3", 1048 | "aria-query": "^4.2.2", 1049 | "array-includes": "^3.1.4", 1050 | "ast-types-flow": "^0.0.7", 1051 | "axe-core": "^4.3.5", 1052 | "axobject-query": "^2.2.0", 1053 | "damerau-levenshtein": "^1.0.7", 1054 | "emoji-regex": "^9.2.2", 1055 | "has": "^1.0.3", 1056 | "jsx-ast-utils": "^3.2.1", 1057 | "language-tags": "^1.0.5", 1058 | "minimatch": "^3.0.4" 1059 | } 1060 | }, 1061 | "eslint-plugin-react": { 1062 | "version": "7.28.0", 1063 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.28.0.tgz", 1064 | "integrity": "sha512-IOlFIRHzWfEQQKcAD4iyYDndHwTQiCMcJVJjxempf203jnNLUnW34AXLrV33+nEXoifJE2ZEGmcjKPL8957eSw==", 1065 | "dev": true, 1066 | "requires": { 1067 | "array-includes": "^3.1.4", 1068 | "array.prototype.flatmap": "^1.2.5", 1069 | "doctrine": "^2.1.0", 1070 | "estraverse": "^5.3.0", 1071 | "jsx-ast-utils": "^2.4.1 || ^3.0.0", 1072 | "minimatch": "^3.0.4", 1073 | "object.entries": "^1.1.5", 1074 | "object.fromentries": "^2.0.5", 1075 | "object.hasown": "^1.1.0", 1076 | "object.values": "^1.1.5", 1077 | "prop-types": "^15.7.2", 1078 | "resolve": "^2.0.0-next.3", 1079 | "semver": "^6.3.0", 1080 | "string.prototype.matchall": "^4.0.6" 1081 | }, 1082 | "dependencies": { 1083 | "doctrine": { 1084 | "version": "2.1.0", 1085 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1086 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1087 | "dev": true, 1088 | "requires": { 1089 | "esutils": "^2.0.2" 1090 | } 1091 | }, 1092 | "resolve": { 1093 | "version": "2.0.0-next.3", 1094 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.3.tgz", 1095 | "integrity": "sha512-W8LucSynKUIDu9ylraa7ueVZ7hc0uAgJBxVsQSKOXOyle8a93qXhcz+XAXZ8bIq2d6i4Ehddn6Evt+0/UwKk6Q==", 1096 | "dev": true, 1097 | "requires": { 1098 | "is-core-module": "^2.2.0", 1099 | "path-parse": "^1.0.6" 1100 | } 1101 | }, 1102 | "semver": { 1103 | "version": "6.3.0", 1104 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1105 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1106 | "dev": true 1107 | } 1108 | } 1109 | }, 1110 | "eslint-plugin-react-hooks": { 1111 | "version": "4.3.0", 1112 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.3.0.tgz", 1113 | "integrity": "sha512-XslZy0LnMn+84NEG9jSGR6eGqaZB3133L8xewQo3fQagbQuGt7a63gf+P1NGKZavEYEC3UXaWEAA/AqDkuN6xA==", 1114 | "dev": true 1115 | }, 1116 | "eslint-scope": { 1117 | "version": "7.1.0", 1118 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.0.tgz", 1119 | "integrity": "sha512-aWwkhnS0qAXqNOgKOK0dJ2nvzEbhEvpy8OlJ9kZ0FeZnA6zpjv1/Vei+puGFFX7zkPCkHHXb7IDX3A+7yPrRWg==", 1120 | "dev": true, 1121 | "requires": { 1122 | "esrecurse": "^4.3.0", 1123 | "estraverse": "^5.2.0" 1124 | } 1125 | }, 1126 | "eslint-utils": { 1127 | "version": "3.0.0", 1128 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 1129 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 1130 | "dev": true, 1131 | "requires": { 1132 | "eslint-visitor-keys": "^2.0.0" 1133 | }, 1134 | "dependencies": { 1135 | "eslint-visitor-keys": { 1136 | "version": "2.1.0", 1137 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 1138 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 1139 | "dev": true 1140 | } 1141 | } 1142 | }, 1143 | "eslint-visitor-keys": { 1144 | "version": "3.2.0", 1145 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.2.0.tgz", 1146 | "integrity": "sha512-IOzT0X126zn7ALX0dwFiUQEdsfzrm4+ISsQS8nukaJXwEyYKRSnEIIDULYg1mCtGp7UUXgfGl7BIolXREQK+XQ==", 1147 | "dev": true 1148 | }, 1149 | "espree": { 1150 | "version": "9.3.0", 1151 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.0.tgz", 1152 | "integrity": "sha512-d/5nCsb0JcqsSEeQzFZ8DH1RmxPcglRWh24EFTlUEmCKoehXGdpsx0RkHDubqUI8LSAIKMQp4r9SzQ3n+sm4HQ==", 1153 | "dev": true, 1154 | "requires": { 1155 | "acorn": "^8.7.0", 1156 | "acorn-jsx": "^5.3.1", 1157 | "eslint-visitor-keys": "^3.1.0" 1158 | } 1159 | }, 1160 | "esquery": { 1161 | "version": "1.4.0", 1162 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 1163 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 1164 | "dev": true, 1165 | "requires": { 1166 | "estraverse": "^5.1.0" 1167 | } 1168 | }, 1169 | "esrecurse": { 1170 | "version": "4.3.0", 1171 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1172 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1173 | "dev": true, 1174 | "requires": { 1175 | "estraverse": "^5.2.0" 1176 | } 1177 | }, 1178 | "estraverse": { 1179 | "version": "5.3.0", 1180 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1181 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1182 | "dev": true 1183 | }, 1184 | "esutils": { 1185 | "version": "2.0.3", 1186 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1187 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1188 | "dev": true 1189 | }, 1190 | "fast-deep-equal": { 1191 | "version": "3.1.3", 1192 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1193 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1194 | "dev": true 1195 | }, 1196 | "fast-glob": { 1197 | "version": "3.2.11", 1198 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.11.tgz", 1199 | "integrity": "sha512-xrO3+1bxSo3ZVHAnqzyuewYT6aMFHRAd4Kcs92MAonjwQZLsK9d0SF1IyQ3k5PoirxTW0Oe/RqFgMQ6TcNE5Ew==", 1200 | "dev": true, 1201 | "requires": { 1202 | "@nodelib/fs.stat": "^2.0.2", 1203 | "@nodelib/fs.walk": "^1.2.3", 1204 | "glob-parent": "^5.1.2", 1205 | "merge2": "^1.3.0", 1206 | "micromatch": "^4.0.4" 1207 | }, 1208 | "dependencies": { 1209 | "glob-parent": { 1210 | "version": "5.1.2", 1211 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1212 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1213 | "dev": true, 1214 | "requires": { 1215 | "is-glob": "^4.0.1" 1216 | } 1217 | } 1218 | } 1219 | }, 1220 | "fast-json-stable-stringify": { 1221 | "version": "2.1.0", 1222 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1223 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1224 | "dev": true 1225 | }, 1226 | "fast-levenshtein": { 1227 | "version": "2.0.6", 1228 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1229 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1230 | "dev": true 1231 | }, 1232 | "fastq": { 1233 | "version": "1.13.0", 1234 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", 1235 | "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", 1236 | "dev": true, 1237 | "requires": { 1238 | "reusify": "^1.0.4" 1239 | } 1240 | }, 1241 | "file-entry-cache": { 1242 | "version": "6.0.1", 1243 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1244 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1245 | "dev": true, 1246 | "requires": { 1247 | "flat-cache": "^3.0.4" 1248 | } 1249 | }, 1250 | "fill-range": { 1251 | "version": "7.0.1", 1252 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1253 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1254 | "dev": true, 1255 | "requires": { 1256 | "to-regex-range": "^5.0.1" 1257 | } 1258 | }, 1259 | "find-up": { 1260 | "version": "2.1.0", 1261 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1262 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1263 | "dev": true, 1264 | "requires": { 1265 | "locate-path": "^2.0.0" 1266 | } 1267 | }, 1268 | "flat-cache": { 1269 | "version": "3.0.4", 1270 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1271 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1272 | "dev": true, 1273 | "requires": { 1274 | "flatted": "^3.1.0", 1275 | "rimraf": "^3.0.2" 1276 | } 1277 | }, 1278 | "flatted": { 1279 | "version": "3.2.5", 1280 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.5.tgz", 1281 | "integrity": "sha512-WIWGi2L3DyTUvUrwRKgGi9TwxQMUEqPOPQBVi71R96jZXJdFskXEmf54BoZaS1kknGODoIGASGEzBUYdyMCBJg==", 1282 | "dev": true 1283 | }, 1284 | "follow-redirects": { 1285 | "version": "1.14.8", 1286 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.8.tgz", 1287 | "integrity": "sha512-1x0S9UVJHsQprFcEC/qnNzBLcIxsjAV905f/UkQxbclCsoTWlacCNOpQa/anodLl2uaEKFhfWOvM2Qg77+15zA==" 1288 | }, 1289 | "form-data": { 1290 | "version": "3.0.1", 1291 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", 1292 | "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", 1293 | "requires": { 1294 | "asynckit": "^0.4.0", 1295 | "combined-stream": "^1.0.8", 1296 | "mime-types": "^2.1.12" 1297 | } 1298 | }, 1299 | "fs.realpath": { 1300 | "version": "1.0.0", 1301 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1302 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1303 | "dev": true 1304 | }, 1305 | "function-bind": { 1306 | "version": "1.1.1", 1307 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1308 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1309 | "dev": true 1310 | }, 1311 | "functional-red-black-tree": { 1312 | "version": "1.0.1", 1313 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1314 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1315 | "dev": true 1316 | }, 1317 | "get-intrinsic": { 1318 | "version": "1.1.1", 1319 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 1320 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 1321 | "dev": true, 1322 | "requires": { 1323 | "function-bind": "^1.1.1", 1324 | "has": "^1.0.3", 1325 | "has-symbols": "^1.0.1" 1326 | } 1327 | }, 1328 | "get-symbol-description": { 1329 | "version": "1.0.0", 1330 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 1331 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 1332 | "dev": true, 1333 | "requires": { 1334 | "call-bind": "^1.0.2", 1335 | "get-intrinsic": "^1.1.1" 1336 | } 1337 | }, 1338 | "glob": { 1339 | "version": "7.2.0", 1340 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 1341 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 1342 | "dev": true, 1343 | "requires": { 1344 | "fs.realpath": "^1.0.0", 1345 | "inflight": "^1.0.4", 1346 | "inherits": "2", 1347 | "minimatch": "^3.0.4", 1348 | "once": "^1.3.0", 1349 | "path-is-absolute": "^1.0.0" 1350 | } 1351 | }, 1352 | "glob-parent": { 1353 | "version": "6.0.2", 1354 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1355 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1356 | "dev": true, 1357 | "requires": { 1358 | "is-glob": "^4.0.3" 1359 | } 1360 | }, 1361 | "globals": { 1362 | "version": "13.12.1", 1363 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.1.tgz", 1364 | "integrity": "sha512-317dFlgY2pdJZ9rspXDks7073GpDmXdfbM3vYYp0HAMKGDh1FfWPleI2ljVNLQX5M5lXcAslTcPTrOrMEFOjyw==", 1365 | "dev": true, 1366 | "requires": { 1367 | "type-fest": "^0.20.2" 1368 | } 1369 | }, 1370 | "globby": { 1371 | "version": "11.1.0", 1372 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 1373 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 1374 | "dev": true, 1375 | "requires": { 1376 | "array-union": "^2.1.0", 1377 | "dir-glob": "^3.0.1", 1378 | "fast-glob": "^3.2.9", 1379 | "ignore": "^5.2.0", 1380 | "merge2": "^1.4.1", 1381 | "slash": "^3.0.0" 1382 | } 1383 | }, 1384 | "has": { 1385 | "version": "1.0.3", 1386 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1387 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1388 | "dev": true, 1389 | "requires": { 1390 | "function-bind": "^1.1.1" 1391 | } 1392 | }, 1393 | "has-bigints": { 1394 | "version": "1.0.1", 1395 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", 1396 | "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", 1397 | "dev": true 1398 | }, 1399 | "has-flag": { 1400 | "version": "4.0.0", 1401 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1402 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1403 | "dev": true 1404 | }, 1405 | "has-symbols": { 1406 | "version": "1.0.2", 1407 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 1408 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 1409 | "dev": true 1410 | }, 1411 | "has-tostringtag": { 1412 | "version": "1.0.0", 1413 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 1414 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 1415 | "dev": true, 1416 | "requires": { 1417 | "has-symbols": "^1.0.2" 1418 | } 1419 | }, 1420 | "ieee754": { 1421 | "version": "1.2.1", 1422 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 1423 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" 1424 | }, 1425 | "ignore": { 1426 | "version": "5.2.0", 1427 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 1428 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 1429 | "dev": true 1430 | }, 1431 | "import-fresh": { 1432 | "version": "3.3.0", 1433 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1434 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1435 | "dev": true, 1436 | "requires": { 1437 | "parent-module": "^1.0.0", 1438 | "resolve-from": "^4.0.0" 1439 | } 1440 | }, 1441 | "imurmurhash": { 1442 | "version": "0.1.4", 1443 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1444 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1445 | "dev": true 1446 | }, 1447 | "inflight": { 1448 | "version": "1.0.6", 1449 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1450 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1451 | "dev": true, 1452 | "requires": { 1453 | "once": "^1.3.0", 1454 | "wrappy": "1" 1455 | } 1456 | }, 1457 | "inherits": { 1458 | "version": "2.0.4", 1459 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1460 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1461 | }, 1462 | "internal-slot": { 1463 | "version": "1.0.3", 1464 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", 1465 | "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", 1466 | "dev": true, 1467 | "requires": { 1468 | "get-intrinsic": "^1.1.0", 1469 | "has": "^1.0.3", 1470 | "side-channel": "^1.0.4" 1471 | } 1472 | }, 1473 | "ip": { 1474 | "version": "1.1.5", 1475 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", 1476 | "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" 1477 | }, 1478 | "is-bigint": { 1479 | "version": "1.0.4", 1480 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 1481 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 1482 | "dev": true, 1483 | "requires": { 1484 | "has-bigints": "^1.0.1" 1485 | } 1486 | }, 1487 | "is-boolean-object": { 1488 | "version": "1.1.2", 1489 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 1490 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 1491 | "dev": true, 1492 | "requires": { 1493 | "call-bind": "^1.0.2", 1494 | "has-tostringtag": "^1.0.0" 1495 | } 1496 | }, 1497 | "is-buffer": { 1498 | "version": "1.1.6", 1499 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1500 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" 1501 | }, 1502 | "is-callable": { 1503 | "version": "1.2.4", 1504 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", 1505 | "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==", 1506 | "dev": true 1507 | }, 1508 | "is-core-module": { 1509 | "version": "2.8.1", 1510 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 1511 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 1512 | "dev": true, 1513 | "requires": { 1514 | "has": "^1.0.3" 1515 | } 1516 | }, 1517 | "is-date-object": { 1518 | "version": "1.0.5", 1519 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 1520 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 1521 | "dev": true, 1522 | "requires": { 1523 | "has-tostringtag": "^1.0.0" 1524 | } 1525 | }, 1526 | "is-extglob": { 1527 | "version": "2.1.1", 1528 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1529 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1530 | "dev": true 1531 | }, 1532 | "is-glob": { 1533 | "version": "4.0.3", 1534 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1535 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1536 | "dev": true, 1537 | "requires": { 1538 | "is-extglob": "^2.1.1" 1539 | } 1540 | }, 1541 | "is-negative-zero": { 1542 | "version": "2.0.2", 1543 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 1544 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", 1545 | "dev": true 1546 | }, 1547 | "is-number": { 1548 | "version": "7.0.0", 1549 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1550 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1551 | "dev": true 1552 | }, 1553 | "is-number-object": { 1554 | "version": "1.0.6", 1555 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.6.tgz", 1556 | "integrity": "sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g==", 1557 | "dev": true, 1558 | "requires": { 1559 | "has-tostringtag": "^1.0.0" 1560 | } 1561 | }, 1562 | "is-regex": { 1563 | "version": "1.1.4", 1564 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 1565 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 1566 | "dev": true, 1567 | "requires": { 1568 | "call-bind": "^1.0.2", 1569 | "has-tostringtag": "^1.0.0" 1570 | } 1571 | }, 1572 | "is-shared-array-buffer": { 1573 | "version": "1.0.1", 1574 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.1.tgz", 1575 | "integrity": "sha512-IU0NmyknYZN0rChcKhRO1X8LYz5Isj/Fsqh8NJOSf+N/hCOTwy29F32Ik7a+QszE63IdvmwdTPDd6cZ5pg4cwA==", 1576 | "dev": true 1577 | }, 1578 | "is-string": { 1579 | "version": "1.0.7", 1580 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 1581 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 1582 | "dev": true, 1583 | "requires": { 1584 | "has-tostringtag": "^1.0.0" 1585 | } 1586 | }, 1587 | "is-symbol": { 1588 | "version": "1.0.4", 1589 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 1590 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 1591 | "dev": true, 1592 | "requires": { 1593 | "has-symbols": "^1.0.2" 1594 | } 1595 | }, 1596 | "is-weakref": { 1597 | "version": "1.0.2", 1598 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 1599 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 1600 | "dev": true, 1601 | "requires": { 1602 | "call-bind": "^1.0.2" 1603 | } 1604 | }, 1605 | "isarray": { 1606 | "version": "0.0.1", 1607 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 1608 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 1609 | }, 1610 | "isexe": { 1611 | "version": "2.0.0", 1612 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1613 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1614 | "dev": true 1615 | }, 1616 | "js-tokens": { 1617 | "version": "4.0.0", 1618 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1619 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 1620 | }, 1621 | "js-yaml": { 1622 | "version": "4.1.0", 1623 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1624 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1625 | "dev": true, 1626 | "requires": { 1627 | "argparse": "^2.0.1" 1628 | } 1629 | }, 1630 | "json-schema-traverse": { 1631 | "version": "0.4.1", 1632 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1633 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1634 | "dev": true 1635 | }, 1636 | "json-stable-stringify-without-jsonify": { 1637 | "version": "1.0.1", 1638 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1639 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1640 | "dev": true 1641 | }, 1642 | "json5": { 1643 | "version": "1.0.1", 1644 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 1645 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 1646 | "dev": true, 1647 | "requires": { 1648 | "minimist": "^1.2.0" 1649 | } 1650 | }, 1651 | "jsonwebtoken": { 1652 | "version": "8.5.1", 1653 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 1654 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 1655 | "requires": { 1656 | "jws": "^3.2.2", 1657 | "lodash.includes": "^4.3.0", 1658 | "lodash.isboolean": "^3.0.3", 1659 | "lodash.isinteger": "^4.0.4", 1660 | "lodash.isnumber": "^3.0.3", 1661 | "lodash.isplainobject": "^4.0.6", 1662 | "lodash.isstring": "^4.0.1", 1663 | "lodash.once": "^4.0.0", 1664 | "ms": "^2.1.1", 1665 | "semver": "^5.6.0" 1666 | }, 1667 | "dependencies": { 1668 | "semver": { 1669 | "version": "5.7.1", 1670 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1671 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1672 | } 1673 | } 1674 | }, 1675 | "jsx-ast-utils": { 1676 | "version": "3.2.1", 1677 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.2.1.tgz", 1678 | "integrity": "sha512-uP5vu8xfy2F9A6LGC22KO7e2/vGTS1MhP+18f++ZNlf0Ohaxbc9nIEwHAsejlJKyzfZzU5UIhe5ItYkitcZnZA==", 1679 | "dev": true, 1680 | "requires": { 1681 | "array-includes": "^3.1.3", 1682 | "object.assign": "^4.1.2" 1683 | } 1684 | }, 1685 | "jwa": { 1686 | "version": "1.4.1", 1687 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 1688 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 1689 | "requires": { 1690 | "buffer-equal-constant-time": "1.0.1", 1691 | "ecdsa-sig-formatter": "1.0.11", 1692 | "safe-buffer": "^5.0.1" 1693 | } 1694 | }, 1695 | "jws": { 1696 | "version": "3.2.2", 1697 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 1698 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 1699 | "requires": { 1700 | "jwa": "^1.4.1", 1701 | "safe-buffer": "^5.0.1" 1702 | } 1703 | }, 1704 | "kareem": { 1705 | "version": "2.3.3", 1706 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.3.tgz", 1707 | "integrity": "sha512-uESCXM2KdtOQ8LOvKyTUXEeg0MkYp4wGglTIpGcYHvjJcS5sn2Wkfrfit8m4xSbaNDAw2KdI9elgkOxZbrFYbg==" 1708 | }, 1709 | "language-subtag-registry": { 1710 | "version": "0.3.21", 1711 | "resolved": "https://registry.npmjs.org/language-subtag-registry/-/language-subtag-registry-0.3.21.tgz", 1712 | "integrity": "sha512-L0IqwlIXjilBVVYKFT37X9Ih11Um5NEl9cbJIuU/SwP/zEEAbBPOnEeeuxVMf45ydWQRDQN3Nqc96OgbH1K+Pg==", 1713 | "dev": true 1714 | }, 1715 | "language-tags": { 1716 | "version": "1.0.5", 1717 | "resolved": "https://registry.npmjs.org/language-tags/-/language-tags-1.0.5.tgz", 1718 | "integrity": "sha1-0yHbxNowuovzAk4ED6XBRmH5GTo=", 1719 | "dev": true, 1720 | "requires": { 1721 | "language-subtag-registry": "~0.3.2" 1722 | } 1723 | }, 1724 | "levn": { 1725 | "version": "0.4.1", 1726 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1727 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1728 | "dev": true, 1729 | "requires": { 1730 | "prelude-ls": "^1.2.1", 1731 | "type-check": "~0.4.0" 1732 | } 1733 | }, 1734 | "locate-path": { 1735 | "version": "2.0.0", 1736 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1737 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1738 | "dev": true, 1739 | "requires": { 1740 | "p-locate": "^2.0.0", 1741 | "path-exists": "^3.0.0" 1742 | } 1743 | }, 1744 | "lodash.includes": { 1745 | "version": "4.3.0", 1746 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1747 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1748 | }, 1749 | "lodash.isboolean": { 1750 | "version": "3.0.3", 1751 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1752 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1753 | }, 1754 | "lodash.isinteger": { 1755 | "version": "4.0.4", 1756 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1757 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1758 | }, 1759 | "lodash.isnumber": { 1760 | "version": "3.0.3", 1761 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1762 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1763 | }, 1764 | "lodash.isplainobject": { 1765 | "version": "4.0.6", 1766 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1767 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1768 | }, 1769 | "lodash.isstring": { 1770 | "version": "4.0.1", 1771 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1772 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1773 | }, 1774 | "lodash.merge": { 1775 | "version": "4.6.2", 1776 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1777 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1778 | "dev": true 1779 | }, 1780 | "lodash.once": { 1781 | "version": "4.1.1", 1782 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1783 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1784 | }, 1785 | "loose-envify": { 1786 | "version": "1.4.0", 1787 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1788 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1789 | "requires": { 1790 | "js-tokens": "^3.0.0 || ^4.0.0" 1791 | } 1792 | }, 1793 | "lru-cache": { 1794 | "version": "6.0.0", 1795 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1796 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1797 | "dev": true, 1798 | "requires": { 1799 | "yallist": "^4.0.0" 1800 | } 1801 | }, 1802 | "md5": { 1803 | "version": "2.3.0", 1804 | "resolved": "https://registry.npmjs.org/md5/-/md5-2.3.0.tgz", 1805 | "integrity": "sha512-T1GITYmFaKuO91vxyoQMFETst+O71VUPEU3ze5GNzDm0OWdP8v1ziTaAEPUr/3kLsY3Sftgz242A1SetQiDL7g==", 1806 | "requires": { 1807 | "charenc": "0.0.2", 1808 | "crypt": "0.0.2", 1809 | "is-buffer": "~1.1.6" 1810 | } 1811 | }, 1812 | "media-typer": { 1813 | "version": "0.3.0", 1814 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1815 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1816 | }, 1817 | "memory-pager": { 1818 | "version": "1.5.0", 1819 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1820 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1821 | "optional": true 1822 | }, 1823 | "merge2": { 1824 | "version": "1.4.1", 1825 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1826 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1827 | "dev": true 1828 | }, 1829 | "micromatch": { 1830 | "version": "4.0.4", 1831 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 1832 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 1833 | "dev": true, 1834 | "requires": { 1835 | "braces": "^3.0.1", 1836 | "picomatch": "^2.2.3" 1837 | } 1838 | }, 1839 | "mime-db": { 1840 | "version": "1.51.0", 1841 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz", 1842 | "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g==" 1843 | }, 1844 | "mime-types": { 1845 | "version": "2.1.34", 1846 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz", 1847 | "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==", 1848 | "requires": { 1849 | "mime-db": "1.51.0" 1850 | } 1851 | }, 1852 | "minimatch": { 1853 | "version": "3.0.5", 1854 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.5.tgz", 1855 | "integrity": "sha512-tUpxzX0VAzJHjLu0xUfFv1gwVp9ba3IOuRAVH2EGuRW8a5emA2FlACLqiT/lDVtS1W+TGNwqz3sWaNyLgDJWuw==", 1856 | "dev": true, 1857 | "requires": { 1858 | "brace-expansion": "^1.1.7" 1859 | } 1860 | }, 1861 | "minimist": { 1862 | "version": "1.2.5", 1863 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1864 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1865 | }, 1866 | "mkdirp": { 1867 | "version": "0.5.5", 1868 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1869 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1870 | "requires": { 1871 | "minimist": "^1.2.5" 1872 | } 1873 | }, 1874 | "moment": { 1875 | "version": "2.29.1", 1876 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 1877 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==" 1878 | }, 1879 | "mongodb": { 1880 | "version": "4.3.1", 1881 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-4.3.1.tgz", 1882 | "integrity": "sha512-sNa8APSIk+r4x31ZwctKjuPSaeKuvUeNb/fu/3B6dRM02HpEgig7hTHM8A/PJQTlxuC/KFWlDlQjhsk/S43tBg==", 1883 | "requires": { 1884 | "bson": "^4.6.1", 1885 | "denque": "^2.0.1", 1886 | "mongodb-connection-string-url": "^2.4.1", 1887 | "saslprep": "^1.0.3", 1888 | "socks": "^2.6.1" 1889 | } 1890 | }, 1891 | "mongodb-connection-string-url": { 1892 | "version": "2.4.2", 1893 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.4.2.tgz", 1894 | "integrity": "sha512-mZUXF6nUzRWk5J3h41MsPv13ukWlH4jOMSk6astVeoZ1EbdTJyF5I3wxKkvqBAOoVtzLgyEYUvDjrGdcPlKjAw==", 1895 | "requires": { 1896 | "@types/whatwg-url": "^8.2.1", 1897 | "whatwg-url": "^11.0.0" 1898 | } 1899 | }, 1900 | "mongoose": { 1901 | "version": "6.2.1", 1902 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-6.2.1.tgz", 1903 | "integrity": "sha512-VxY1wvlc4uBQKyKNVDoEkTU3/ayFOD//qVXYP+sFyvTRbAj9/M53UWTERd84pWogs2TqAC6DTvZbxCs2LoOd3Q==", 1904 | "requires": { 1905 | "bson": "^4.2.2", 1906 | "kareem": "2.3.3", 1907 | "mongodb": "4.3.1", 1908 | "mpath": "0.8.4", 1909 | "mquery": "4.0.2", 1910 | "ms": "2.1.2", 1911 | "sift": "13.5.2" 1912 | } 1913 | }, 1914 | "mpath": { 1915 | "version": "0.8.4", 1916 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.4.tgz", 1917 | "integrity": "sha512-DTxNZomBcTWlrMW76jy1wvV37X/cNNxPW1y2Jzd4DZkAaC5ZGsm8bfGfNOthcDuRJujXLqiuS6o3Tpy0JEoh7g==" 1918 | }, 1919 | "mquery": { 1920 | "version": "4.0.2", 1921 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-4.0.2.tgz", 1922 | "integrity": "sha512-oAVF0Nil1mT3rxty6Zln4YiD6x6QsUWYz927jZzjMxOK2aqmhEz5JQ7xmrKK7xRFA2dwV+YaOpKU/S+vfNqKxA==", 1923 | "requires": { 1924 | "debug": "4.x" 1925 | } 1926 | }, 1927 | "ms": { 1928 | "version": "2.1.2", 1929 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1930 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1931 | }, 1932 | "multer": { 1933 | "version": "1.4.4", 1934 | "resolved": "https://registry.npmjs.org/multer/-/multer-1.4.4.tgz", 1935 | "integrity": "sha512-2wY2+xD4udX612aMqMcB8Ws2Voq6NIUPEtD1be6m411T4uDH/VtL9i//xvcyFlTVfRdaBsk7hV5tgrGQqhuBiw==", 1936 | "requires": { 1937 | "append-field": "^1.0.0", 1938 | "busboy": "^0.2.11", 1939 | "concat-stream": "^1.5.2", 1940 | "mkdirp": "^0.5.4", 1941 | "object-assign": "^4.1.1", 1942 | "on-finished": "^2.3.0", 1943 | "type-is": "^1.6.4", 1944 | "xtend": "^4.0.0" 1945 | } 1946 | }, 1947 | "nanoid": { 1948 | "version": "3.2.0", 1949 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.2.0.tgz", 1950 | "integrity": "sha512-fmsZYa9lpn69Ad5eDn7FMcnnSR+8R34W9qJEijxYhTbfOWzr22n1QxCMzXLK+ODyW2973V3Fux959iQoUxzUIA==" 1951 | }, 1952 | "natural-compare": { 1953 | "version": "1.4.0", 1954 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1955 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1956 | "dev": true 1957 | }, 1958 | "next": { 1959 | "version": "12.0.10", 1960 | "resolved": "https://registry.npmjs.org/next/-/next-12.0.10.tgz", 1961 | "integrity": "sha512-1y3PpGzpb/EZzz1jgne+JfZXKAVJUjYXwxzrADf/LWN+8yi9o79vMLXpW3mevvCHkEF2sBnIdjzNn16TJrINUw==", 1962 | "requires": { 1963 | "@next/env": "12.0.10", 1964 | "@next/swc-android-arm64": "12.0.10", 1965 | "@next/swc-darwin-arm64": "12.0.10", 1966 | "@next/swc-darwin-x64": "12.0.10", 1967 | "@next/swc-linux-arm-gnueabihf": "12.0.10", 1968 | "@next/swc-linux-arm64-gnu": "12.0.10", 1969 | "@next/swc-linux-arm64-musl": "12.0.10", 1970 | "@next/swc-linux-x64-gnu": "12.0.10", 1971 | "@next/swc-linux-x64-musl": "12.0.10", 1972 | "@next/swc-win32-arm64-msvc": "12.0.10", 1973 | "@next/swc-win32-ia32-msvc": "12.0.10", 1974 | "@next/swc-win32-x64-msvc": "12.0.10", 1975 | "caniuse-lite": "^1.0.30001283", 1976 | "postcss": "8.4.5", 1977 | "styled-jsx": "5.0.0", 1978 | "use-subscription": "1.5.1" 1979 | } 1980 | }, 1981 | "next-connect": { 1982 | "version": "0.12.1", 1983 | "resolved": "https://registry.npmjs.org/next-connect/-/next-connect-0.12.1.tgz", 1984 | "integrity": "sha512-pzW3oKCYAaNOxQncIIv53cHrRaZSeQ2KZ9chjYx/OHgASV8qDNlVvD3Mz9RTrO9TuJs3kjt0VeTBGJmoE/yl2g==", 1985 | "requires": { 1986 | "trouter": "^3.2.0" 1987 | } 1988 | }, 1989 | "nextjs-cors": { 1990 | "version": "2.1.0", 1991 | "resolved": "https://registry.npmjs.org/nextjs-cors/-/nextjs-cors-2.1.0.tgz", 1992 | "integrity": "sha512-FC1LJMebe6E9fQ3hapW/4Q6zpz1Xpq8O8A2mYWma3S5EY8BP/t+IiTFsHm8Js5lRNyJ3DzQG/3VQu9pTA2LS/Q==", 1993 | "requires": { 1994 | "cors": "^2.8.5" 1995 | } 1996 | }, 1997 | "object-assign": { 1998 | "version": "4.1.1", 1999 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2000 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 2001 | }, 2002 | "object-inspect": { 2003 | "version": "1.12.0", 2004 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.0.tgz", 2005 | "integrity": "sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g==", 2006 | "dev": true 2007 | }, 2008 | "object-keys": { 2009 | "version": "1.1.1", 2010 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2011 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2012 | "dev": true 2013 | }, 2014 | "object.assign": { 2015 | "version": "4.1.2", 2016 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 2017 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 2018 | "dev": true, 2019 | "requires": { 2020 | "call-bind": "^1.0.0", 2021 | "define-properties": "^1.1.3", 2022 | "has-symbols": "^1.0.1", 2023 | "object-keys": "^1.1.1" 2024 | } 2025 | }, 2026 | "object.entries": { 2027 | "version": "1.1.5", 2028 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.5.tgz", 2029 | "integrity": "sha512-TyxmjUoZggd4OrrU1W66FMDG6CuqJxsFvymeyXI51+vQLN67zYfZseptRge703kKQdo4uccgAKebXFcRCzk4+g==", 2030 | "dev": true, 2031 | "requires": { 2032 | "call-bind": "^1.0.2", 2033 | "define-properties": "^1.1.3", 2034 | "es-abstract": "^1.19.1" 2035 | } 2036 | }, 2037 | "object.fromentries": { 2038 | "version": "2.0.5", 2039 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.5.tgz", 2040 | "integrity": "sha512-CAyG5mWQRRiBU57Re4FKoTBjXfDoNwdFVH2Y1tS9PqCsfUTymAohOkEMSG3aRNKmv4lV3O7p1et7c187q6bynw==", 2041 | "dev": true, 2042 | "requires": { 2043 | "call-bind": "^1.0.2", 2044 | "define-properties": "^1.1.3", 2045 | "es-abstract": "^1.19.1" 2046 | } 2047 | }, 2048 | "object.hasown": { 2049 | "version": "1.1.0", 2050 | "resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.0.tgz", 2051 | "integrity": "sha512-MhjYRfj3GBlhSkDHo6QmvgjRLXQ2zndabdf3nX0yTyZK9rPfxb6uRpAac8HXNLy1GpqWtZ81Qh4v3uOls2sRAg==", 2052 | "dev": true, 2053 | "requires": { 2054 | "define-properties": "^1.1.3", 2055 | "es-abstract": "^1.19.1" 2056 | } 2057 | }, 2058 | "object.values": { 2059 | "version": "1.1.5", 2060 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.5.tgz", 2061 | "integrity": "sha512-QUZRW0ilQ3PnPpbNtgdNV1PDbEqLIiSFB3l+EnGtBQ/8SUTLj1PZwtQHABZtLgwpJZTSZhuGLOGk57Drx2IvYg==", 2062 | "dev": true, 2063 | "requires": { 2064 | "call-bind": "^1.0.2", 2065 | "define-properties": "^1.1.3", 2066 | "es-abstract": "^1.19.1" 2067 | } 2068 | }, 2069 | "on-finished": { 2070 | "version": "2.3.0", 2071 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2072 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2073 | "requires": { 2074 | "ee-first": "1.1.1" 2075 | } 2076 | }, 2077 | "once": { 2078 | "version": "1.4.0", 2079 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2080 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2081 | "dev": true, 2082 | "requires": { 2083 | "wrappy": "1" 2084 | } 2085 | }, 2086 | "optionator": { 2087 | "version": "0.9.1", 2088 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2089 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2090 | "dev": true, 2091 | "requires": { 2092 | "deep-is": "^0.1.3", 2093 | "fast-levenshtein": "^2.0.6", 2094 | "levn": "^0.4.1", 2095 | "prelude-ls": "^1.2.1", 2096 | "type-check": "^0.4.0", 2097 | "word-wrap": "^1.2.3" 2098 | } 2099 | }, 2100 | "p-limit": { 2101 | "version": "1.3.0", 2102 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 2103 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 2104 | "dev": true, 2105 | "requires": { 2106 | "p-try": "^1.0.0" 2107 | } 2108 | }, 2109 | "p-locate": { 2110 | "version": "2.0.0", 2111 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 2112 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 2113 | "dev": true, 2114 | "requires": { 2115 | "p-limit": "^1.1.0" 2116 | } 2117 | }, 2118 | "p-try": { 2119 | "version": "1.0.0", 2120 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 2121 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 2122 | "dev": true 2123 | }, 2124 | "parent-module": { 2125 | "version": "1.0.1", 2126 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2127 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2128 | "dev": true, 2129 | "requires": { 2130 | "callsites": "^3.0.0" 2131 | } 2132 | }, 2133 | "path-exists": { 2134 | "version": "3.0.0", 2135 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2136 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2137 | "dev": true 2138 | }, 2139 | "path-is-absolute": { 2140 | "version": "1.0.1", 2141 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2142 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2143 | "dev": true 2144 | }, 2145 | "path-key": { 2146 | "version": "3.1.1", 2147 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2148 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2149 | "dev": true 2150 | }, 2151 | "path-parse": { 2152 | "version": "1.0.7", 2153 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2154 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2155 | "dev": true 2156 | }, 2157 | "path-type": { 2158 | "version": "4.0.0", 2159 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2160 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2161 | "dev": true 2162 | }, 2163 | "picocolors": { 2164 | "version": "1.0.0", 2165 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2166 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" 2167 | }, 2168 | "picomatch": { 2169 | "version": "2.3.1", 2170 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2171 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2172 | "dev": true 2173 | }, 2174 | "postcss": { 2175 | "version": "8.4.5", 2176 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.5.tgz", 2177 | "integrity": "sha512-jBDboWM8qpaqwkMwItqTQTiFikhs/67OYVvblFFTM7MrZjt6yMKd6r2kgXizEbTTljacm4NldIlZnhbjr84QYg==", 2178 | "requires": { 2179 | "nanoid": "^3.1.30", 2180 | "picocolors": "^1.0.0", 2181 | "source-map-js": "^1.0.1" 2182 | } 2183 | }, 2184 | "prelude-ls": { 2185 | "version": "1.2.1", 2186 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2187 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2188 | "dev": true 2189 | }, 2190 | "process-nextick-args": { 2191 | "version": "2.0.1", 2192 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2193 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 2194 | }, 2195 | "prop-types": { 2196 | "version": "15.8.1", 2197 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", 2198 | "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", 2199 | "dev": true, 2200 | "requires": { 2201 | "loose-envify": "^1.4.0", 2202 | "object-assign": "^4.1.1", 2203 | "react-is": "^16.13.1" 2204 | } 2205 | }, 2206 | "punycode": { 2207 | "version": "2.1.1", 2208 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2209 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 2210 | }, 2211 | "queue-microtask": { 2212 | "version": "1.2.3", 2213 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2214 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2215 | "dev": true 2216 | }, 2217 | "react": { 2218 | "version": "17.0.2", 2219 | "resolved": "https://registry.npmjs.org/react/-/react-17.0.2.tgz", 2220 | "integrity": "sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA==", 2221 | "requires": { 2222 | "loose-envify": "^1.1.0", 2223 | "object-assign": "^4.1.1" 2224 | } 2225 | }, 2226 | "react-dom": { 2227 | "version": "17.0.2", 2228 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-17.0.2.tgz", 2229 | "integrity": "sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA==", 2230 | "requires": { 2231 | "loose-envify": "^1.1.0", 2232 | "object-assign": "^4.1.1", 2233 | "scheduler": "^0.20.2" 2234 | } 2235 | }, 2236 | "react-is": { 2237 | "version": "16.13.1", 2238 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 2239 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", 2240 | "dev": true 2241 | }, 2242 | "readable-stream": { 2243 | "version": "1.1.14", 2244 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 2245 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 2246 | "requires": { 2247 | "core-util-is": "~1.0.0", 2248 | "inherits": "~2.0.1", 2249 | "isarray": "0.0.1", 2250 | "string_decoder": "~0.10.x" 2251 | } 2252 | }, 2253 | "regenerator-runtime": { 2254 | "version": "0.13.9", 2255 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz", 2256 | "integrity": "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==", 2257 | "dev": true 2258 | }, 2259 | "regexp.prototype.flags": { 2260 | "version": "1.4.1", 2261 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.4.1.tgz", 2262 | "integrity": "sha512-pMR7hBVUUGI7PMA37m2ofIdQCsomVnas+Jn5UPGAHQ+/LlwKm/aTLJHdasmHRzlfeZwHiAOaRSo2rbBDm3nNUQ==", 2263 | "dev": true, 2264 | "requires": { 2265 | "call-bind": "^1.0.2", 2266 | "define-properties": "^1.1.3" 2267 | } 2268 | }, 2269 | "regexparam": { 2270 | "version": "1.3.0", 2271 | "resolved": "https://registry.npmjs.org/regexparam/-/regexparam-1.3.0.tgz", 2272 | "integrity": "sha512-6IQpFBv6e5vz1QAqI+V4k8P2e/3gRrqfCJ9FI+O1FLQTO+Uz6RXZEZOPmTJ6hlGj7gkERzY5BRCv09whKP96/g==" 2273 | }, 2274 | "regexpp": { 2275 | "version": "3.2.0", 2276 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 2277 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 2278 | "dev": true 2279 | }, 2280 | "resolve": { 2281 | "version": "1.22.0", 2282 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 2283 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 2284 | "dev": true, 2285 | "requires": { 2286 | "is-core-module": "^2.8.1", 2287 | "path-parse": "^1.0.7", 2288 | "supports-preserve-symlinks-flag": "^1.0.0" 2289 | } 2290 | }, 2291 | "resolve-from": { 2292 | "version": "4.0.0", 2293 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2294 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2295 | "dev": true 2296 | }, 2297 | "reusify": { 2298 | "version": "1.0.4", 2299 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2300 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2301 | "dev": true 2302 | }, 2303 | "rimraf": { 2304 | "version": "3.0.2", 2305 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2306 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2307 | "dev": true, 2308 | "requires": { 2309 | "glob": "^7.1.3" 2310 | } 2311 | }, 2312 | "run-parallel": { 2313 | "version": "1.2.0", 2314 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2315 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2316 | "dev": true, 2317 | "requires": { 2318 | "queue-microtask": "^1.2.2" 2319 | } 2320 | }, 2321 | "safe-buffer": { 2322 | "version": "5.2.1", 2323 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2324 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2325 | }, 2326 | "saslprep": { 2327 | "version": "1.0.3", 2328 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 2329 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 2330 | "optional": true, 2331 | "requires": { 2332 | "sparse-bitfield": "^3.0.3" 2333 | } 2334 | }, 2335 | "scheduler": { 2336 | "version": "0.20.2", 2337 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.20.2.tgz", 2338 | "integrity": "sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ==", 2339 | "requires": { 2340 | "loose-envify": "^1.1.0", 2341 | "object-assign": "^4.1.1" 2342 | } 2343 | }, 2344 | "semver": { 2345 | "version": "7.3.5", 2346 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 2347 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 2348 | "dev": true, 2349 | "requires": { 2350 | "lru-cache": "^6.0.0" 2351 | } 2352 | }, 2353 | "shebang-command": { 2354 | "version": "2.0.0", 2355 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2356 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2357 | "dev": true, 2358 | "requires": { 2359 | "shebang-regex": "^3.0.0" 2360 | } 2361 | }, 2362 | "shebang-regex": { 2363 | "version": "3.0.0", 2364 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2365 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2366 | "dev": true 2367 | }, 2368 | "side-channel": { 2369 | "version": "1.0.4", 2370 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2371 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2372 | "dev": true, 2373 | "requires": { 2374 | "call-bind": "^1.0.0", 2375 | "get-intrinsic": "^1.0.2", 2376 | "object-inspect": "^1.9.0" 2377 | } 2378 | }, 2379 | "sift": { 2380 | "version": "13.5.2", 2381 | "resolved": "https://registry.npmjs.org/sift/-/sift-13.5.2.tgz", 2382 | "integrity": "sha512-+gxdEOMA2J+AI+fVsCqeNn7Tgx3M9ZN9jdi95939l1IJ8cZsqS8sqpJyOkic2SJk+1+98Uwryt/gL6XDaV+UZA==" 2383 | }, 2384 | "slash": { 2385 | "version": "3.0.0", 2386 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2387 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2388 | "dev": true 2389 | }, 2390 | "smart-buffer": { 2391 | "version": "4.2.0", 2392 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 2393 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" 2394 | }, 2395 | "socks": { 2396 | "version": "2.6.2", 2397 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.6.2.tgz", 2398 | "integrity": "sha512-zDZhHhZRY9PxRruRMR7kMhnf3I8hDs4S3f9RecfnGxvcBHQcKcIH/oUcEWffsfl1XxdYlA7nnlGbbTvPz9D8gA==", 2399 | "requires": { 2400 | "ip": "^1.1.5", 2401 | "smart-buffer": "^4.2.0" 2402 | } 2403 | }, 2404 | "source-map-js": { 2405 | "version": "1.0.2", 2406 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 2407 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==" 2408 | }, 2409 | "sparse-bitfield": { 2410 | "version": "3.0.3", 2411 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 2412 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 2413 | "optional": true, 2414 | "requires": { 2415 | "memory-pager": "^1.0.2" 2416 | } 2417 | }, 2418 | "streamsearch": { 2419 | "version": "0.1.2", 2420 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-0.1.2.tgz", 2421 | "integrity": "sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo=" 2422 | }, 2423 | "string.prototype.matchall": { 2424 | "version": "4.0.6", 2425 | "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.6.tgz", 2426 | "integrity": "sha512-6WgDX8HmQqvEd7J+G6VtAahhsQIssiZ8zl7zKh1VDMFyL3hRTJP4FTNA3RbIp2TOQ9AYNDcc7e3fH0Qbup+DBg==", 2427 | "dev": true, 2428 | "requires": { 2429 | "call-bind": "^1.0.2", 2430 | "define-properties": "^1.1.3", 2431 | "es-abstract": "^1.19.1", 2432 | "get-intrinsic": "^1.1.1", 2433 | "has-symbols": "^1.0.2", 2434 | "internal-slot": "^1.0.3", 2435 | "regexp.prototype.flags": "^1.3.1", 2436 | "side-channel": "^1.0.4" 2437 | } 2438 | }, 2439 | "string.prototype.trimend": { 2440 | "version": "1.0.4", 2441 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", 2442 | "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", 2443 | "dev": true, 2444 | "requires": { 2445 | "call-bind": "^1.0.2", 2446 | "define-properties": "^1.1.3" 2447 | } 2448 | }, 2449 | "string.prototype.trimstart": { 2450 | "version": "1.0.4", 2451 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", 2452 | "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", 2453 | "dev": true, 2454 | "requires": { 2455 | "call-bind": "^1.0.2", 2456 | "define-properties": "^1.1.3" 2457 | } 2458 | }, 2459 | "string_decoder": { 2460 | "version": "0.10.31", 2461 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 2462 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 2463 | }, 2464 | "strip-ansi": { 2465 | "version": "6.0.1", 2466 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2467 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2468 | "dev": true, 2469 | "requires": { 2470 | "ansi-regex": "^5.0.1" 2471 | } 2472 | }, 2473 | "strip-bom": { 2474 | "version": "3.0.0", 2475 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2476 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2477 | "dev": true 2478 | }, 2479 | "strip-json-comments": { 2480 | "version": "3.1.1", 2481 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2482 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2483 | "dev": true 2484 | }, 2485 | "styled-jsx": { 2486 | "version": "5.0.0", 2487 | "resolved": "https://registry.npmjs.org/styled-jsx/-/styled-jsx-5.0.0.tgz", 2488 | "integrity": "sha512-qUqsWoBquEdERe10EW8vLp3jT25s/ssG1/qX5gZ4wu15OZpmSMFI2v+fWlRhLfykA5rFtlJ1ME8A8pm/peV4WA==" 2489 | }, 2490 | "supports-color": { 2491 | "version": "7.2.0", 2492 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2493 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2494 | "dev": true, 2495 | "requires": { 2496 | "has-flag": "^4.0.0" 2497 | } 2498 | }, 2499 | "supports-preserve-symlinks-flag": { 2500 | "version": "1.0.0", 2501 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2502 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2503 | "dev": true 2504 | }, 2505 | "text-table": { 2506 | "version": "0.2.0", 2507 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2508 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2509 | "dev": true 2510 | }, 2511 | "to-regex-range": { 2512 | "version": "5.0.1", 2513 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2514 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2515 | "dev": true, 2516 | "requires": { 2517 | "is-number": "^7.0.0" 2518 | } 2519 | }, 2520 | "tr46": { 2521 | "version": "3.0.0", 2522 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 2523 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 2524 | "requires": { 2525 | "punycode": "^2.1.1" 2526 | } 2527 | }, 2528 | "trouter": { 2529 | "version": "3.2.0", 2530 | "resolved": "https://registry.npmjs.org/trouter/-/trouter-3.2.0.tgz", 2531 | "integrity": "sha512-rLLXbhTObLy2MBVjLC+jTnoIKw99n0GuJs9ov10J870vDw5qhTurPzsDrudNtBf5w/CZ9ctZy2p2IMmhGcel2w==", 2532 | "requires": { 2533 | "regexparam": "^1.3.0" 2534 | } 2535 | }, 2536 | "tsconfig-paths": { 2537 | "version": "3.12.0", 2538 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.12.0.tgz", 2539 | "integrity": "sha512-e5adrnOYT6zqVnWqZu7i/BQ3BnhzvGbjEjejFXO20lKIKpwTaupkCPgEfv4GZK1IBciJUEhYs3J3p75FdaTFVg==", 2540 | "dev": true, 2541 | "requires": { 2542 | "@types/json5": "^0.0.29", 2543 | "json5": "^1.0.1", 2544 | "minimist": "^1.2.0", 2545 | "strip-bom": "^3.0.0" 2546 | } 2547 | }, 2548 | "tslib": { 2549 | "version": "1.14.1", 2550 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2551 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2552 | "dev": true 2553 | }, 2554 | "tsutils": { 2555 | "version": "3.21.0", 2556 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 2557 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 2558 | "dev": true, 2559 | "requires": { 2560 | "tslib": "^1.8.1" 2561 | } 2562 | }, 2563 | "type-check": { 2564 | "version": "0.4.0", 2565 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2566 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2567 | "dev": true, 2568 | "requires": { 2569 | "prelude-ls": "^1.2.1" 2570 | } 2571 | }, 2572 | "type-fest": { 2573 | "version": "0.20.2", 2574 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2575 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2576 | "dev": true 2577 | }, 2578 | "type-is": { 2579 | "version": "1.6.18", 2580 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2581 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2582 | "requires": { 2583 | "media-typer": "0.3.0", 2584 | "mime-types": "~2.1.24" 2585 | } 2586 | }, 2587 | "typedarray": { 2588 | "version": "0.0.6", 2589 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 2590 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" 2591 | }, 2592 | "typescript": { 2593 | "version": "4.5.5", 2594 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.5.tgz", 2595 | "integrity": "sha512-TCTIul70LyWe6IJWT8QSYeA54WQe8EjQFU4wY52Fasj5UKx88LNYKCgBEHcOMOrFF1rKGbD8v/xcNWVUq9SymA==", 2596 | "dev": true 2597 | }, 2598 | "unbox-primitive": { 2599 | "version": "1.0.1", 2600 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", 2601 | "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", 2602 | "dev": true, 2603 | "requires": { 2604 | "function-bind": "^1.1.1", 2605 | "has-bigints": "^1.0.1", 2606 | "has-symbols": "^1.0.2", 2607 | "which-boxed-primitive": "^1.0.2" 2608 | } 2609 | }, 2610 | "uri-js": { 2611 | "version": "4.4.1", 2612 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2613 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2614 | "dev": true, 2615 | "requires": { 2616 | "punycode": "^2.1.0" 2617 | } 2618 | }, 2619 | "use-subscription": { 2620 | "version": "1.5.1", 2621 | "resolved": "https://registry.npmjs.org/use-subscription/-/use-subscription-1.5.1.tgz", 2622 | "integrity": "sha512-Xv2a1P/yReAjAbhylMfFplFKj9GssgTwN7RlcTxBujFQcloStWNDQdc4g4NRWH9xS4i/FDk04vQBptAXoF3VcA==", 2623 | "requires": { 2624 | "object-assign": "^4.1.1" 2625 | } 2626 | }, 2627 | "util-deprecate": { 2628 | "version": "1.0.2", 2629 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2630 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2631 | }, 2632 | "v8-compile-cache": { 2633 | "version": "2.3.0", 2634 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 2635 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 2636 | "dev": true 2637 | }, 2638 | "vary": { 2639 | "version": "1.1.2", 2640 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2641 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2642 | }, 2643 | "webidl-conversions": { 2644 | "version": "7.0.0", 2645 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 2646 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==" 2647 | }, 2648 | "whatwg-url": { 2649 | "version": "11.0.0", 2650 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 2651 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 2652 | "requires": { 2653 | "tr46": "^3.0.0", 2654 | "webidl-conversions": "^7.0.0" 2655 | } 2656 | }, 2657 | "which": { 2658 | "version": "2.0.2", 2659 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2660 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2661 | "dev": true, 2662 | "requires": { 2663 | "isexe": "^2.0.0" 2664 | } 2665 | }, 2666 | "which-boxed-primitive": { 2667 | "version": "1.0.2", 2668 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 2669 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 2670 | "dev": true, 2671 | "requires": { 2672 | "is-bigint": "^1.0.1", 2673 | "is-boolean-object": "^1.1.0", 2674 | "is-number-object": "^1.0.4", 2675 | "is-string": "^1.0.5", 2676 | "is-symbol": "^1.0.3" 2677 | } 2678 | }, 2679 | "word-wrap": { 2680 | "version": "1.2.3", 2681 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2682 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2683 | "dev": true 2684 | }, 2685 | "wrappy": { 2686 | "version": "1.0.2", 2687 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2688 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2689 | "dev": true 2690 | }, 2691 | "xtend": { 2692 | "version": "4.0.2", 2693 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2694 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" 2695 | }, 2696 | "yallist": { 2697 | "version": "4.0.0", 2698 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2699 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2700 | "dev": true 2701 | } 2702 | } 2703 | } 2704 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "devagram-node-nextjs", 3 | "private": true, 4 | "scripts": { 5 | "dev": "next dev", 6 | "build": "next build", 7 | "start": "next start", 8 | "lint": "next lint" 9 | }, 10 | "dependencies": { 11 | "cosmicjs": "^4.1.2", 12 | "jsonwebtoken": "^8.5.1", 13 | "md5": "^2.3.0", 14 | "moment": "^2.29.1", 15 | "mongoose": "^6.2.1", 16 | "multer": "^1.4.4", 17 | "next": "12.0.10", 18 | "next-connect": "^0.12.1", 19 | "nextjs-cors": "^2.1.0", 20 | "react": "17.0.2", 21 | "react-dom": "17.0.2" 22 | }, 23 | "devDependencies": { 24 | "@types/jsonwebtoken": "^8.5.8", 25 | "@types/md5": "^2.3.2", 26 | "@types/multer": "^1.4.7", 27 | "@types/node": "17.0.16", 28 | "@types/react": "17.0.39", 29 | "eslint": "8.8.0", 30 | "eslint-config-next": "12.0.10", 31 | "typescript": "4.5.5" 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /pages/api/cadastro.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse} from 'next'; 2 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 3 | import type {CadastroRequisicao} from '../../types/CadastroRequisicao'; 4 | import {UsuarioModel} from '../../models/UsuarioModel'; 5 | import {conectarMongoDB} from '../../middlewares/conectarMongoDB'; 6 | import md5 from 'md5'; 7 | import {updload, uploadImagemCosmic} from '../../services/uploadImagemCosmic'; 8 | import nc from 'next-connect'; 9 | import { politicaCORS } from '../../middlewares/politicaCORS'; 10 | 11 | const handler = nc() 12 | .use(updload.single('file')) 13 | .post(async (req : NextApiRequest, res : NextApiResponse) => { 14 | try{ 15 | const usuario = req.body as CadastroRequisicao; 16 | 17 | if(!usuario.nome || usuario.nome.length < 2){ 18 | return res.status(400).json({erro : 'Nome invalido'}); 19 | } 20 | 21 | if(!usuario.email || usuario.email.length < 5 22 | || !usuario.email.includes('@') 23 | || !usuario.email.includes('.')){ 24 | return res.status(400).json({erro : 'Email invalido'}); 25 | } 26 | 27 | if(!usuario.senha || usuario.senha.length < 4){ 28 | return res.status(400).json({erro : 'Senha invalida'}); 29 | } 30 | 31 | // validacao se ja existe usuario com o mesmo email 32 | const usuariosComMesmoEmail = await UsuarioModel.find({email : usuario.email}); 33 | if(usuariosComMesmoEmail && usuariosComMesmoEmail.length > 0){ 34 | return res.status(400).json({erro : 'Ja existe uma conta com o email informado'}); 35 | } 36 | 37 | // enviar a imagem do multer para o cosmic 38 | const image = await uploadImagemCosmic(req); 39 | 40 | // salvar no banco de dados 41 | const usuarioASerSalvo = { 42 | nome : usuario.nome, 43 | email : usuario.email, 44 | senha : md5(usuario.senha), 45 | avatar : image?.media?.url 46 | } 47 | await UsuarioModel.create(usuarioASerSalvo); 48 | return res.status(200).json({msg : 'Usuario criado com sucesso'}); 49 | }catch(e : any){ 50 | console.log(e); 51 | return res.status(400).json({erro : e.toString()}); 52 | } 53 | }); 54 | 55 | export const config = { 56 | api: { 57 | bodyParser : false 58 | } 59 | } 60 | 61 | export default politicaCORS(conectarMongoDB(handler)); -------------------------------------------------------------------------------- /pages/api/comentario.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse} from 'next'; 2 | import { conectarMongoDB } from '../../middlewares/conectarMongoDB'; 3 | import { politicaCORS } from '../../middlewares/politicaCORS'; 4 | import { validarTokenJWT } from '../../middlewares/validarTokenJWT'; 5 | import { PublicacaoModel } from '../../models/PublicacaoModel'; 6 | import { UsuarioModel } from '../../models/UsuarioModel'; 7 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 8 | 9 | const comentarioEndpoint = async (req : NextApiRequest, res : NextApiResponse) => { 10 | try{ 11 | if(req.method === 'PUT'){ 12 | const {userId, id} = req.query; 13 | const usuarioLogado = await UsuarioModel.findById(userId); 14 | if(!usuarioLogado){ 15 | return res.status(400).json({erro : 'Usuario nao encontrado'}); 16 | } 17 | 18 | const publicacao = await PublicacaoModel.findById(id); 19 | if(!publicacao){ 20 | return res.status(400).json({erro : 'Publicacao nao encontrada'}); 21 | } 22 | 23 | if(!req.body || !req.body.comentario 24 | || req.body.comentario.length < 2){ 25 | return res.status(400).json({erro : 'Comentario nao e valido'}); 26 | } 27 | 28 | const comentario = { 29 | usuarioId : usuarioLogado._id, 30 | nome : usuarioLogado.nome, 31 | comentario : req.body.comentario 32 | } 33 | 34 | publicacao.comentarios.push(comentario); 35 | await PublicacaoModel.findByIdAndUpdate({_id : publicacao._id}, publicacao); 36 | return res.status(200).json({msg : 'Comentario adicionado com sucesso'}); 37 | } 38 | 39 | return res.status(405).json({erro : 'Metodo informado nao e valido'}); 40 | }catch(e){ 41 | console.log(e); 42 | return res.status(500).json({erro : 'Ocorreu erro ao adicionar comentario'}); 43 | } 44 | } 45 | 46 | export default politicaCORS(validarTokenJWT(conectarMongoDB(comentarioEndpoint))); -------------------------------------------------------------------------------- /pages/api/feed.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse} from 'next'; 2 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 3 | import {validarTokenJWT} from '../../middlewares/validarTokenJWT'; 4 | import {conectarMongoDB} from '../../middlewares/conectarMongoDB'; 5 | import { UsuarioModel } from '../../models/UsuarioModel'; 6 | import { PublicacaoModel } from '../../models/PublicacaoModel'; 7 | import { SeguidorModel } from '../../models/SeguidorModel'; 8 | import { politicaCORS } from '../../middlewares/politicaCORS'; 9 | 10 | const feedEndpoint = async (req : NextApiRequest, res : NextApiResponse) => { 11 | try{ 12 | if(req.method === 'GET'){ 13 | if(req?.query?.id){ 14 | // agora q tenho o id do usuario 15 | // como eu valido se o usuario valido 16 | const usuario = await UsuarioModel.findById(req?.query?.id); 17 | if(!usuario){ 18 | return res.status(400).json({erro : 'Usuario nao encontrado'}); 19 | } 20 | 21 | // e como eu busco as publicacoes dele? 22 | const publicacoes = await PublicacaoModel 23 | .find({idUsuario : usuario._id}) 24 | .sort({data : -1}); 25 | 26 | return res.status(200).json(publicacoes); 27 | }else{ 28 | const {userId} = req.query; 29 | const usuarioLogado = await UsuarioModel.findById(userId); 30 | if(!usuarioLogado){ 31 | return res.status(400).json({erro : 'Usuario nao encontrado'}); 32 | } 33 | 34 | const seguidores = await SeguidorModel.find({usuarioId : usuarioLogado._id}); 35 | const seguidoresIds = seguidores.map(s => s.usuarioSeguidoId); 36 | 37 | const publicacoes = await PublicacaoModel.find({ 38 | $or : [ 39 | {idUsuario : usuarioLogado._id}, 40 | {idUsuario : seguidoresIds} 41 | ] 42 | }) 43 | .sort({data : -1}); 44 | 45 | const result = []; 46 | for (const publicacao of publicacoes) { 47 | const usuarioDaPublicacao = await UsuarioModel.findById(publicacao.idUsuario); 48 | if(usuarioDaPublicacao){ 49 | const final = {...publicacao._doc, usuario : { 50 | nome : usuarioDaPublicacao.nome, 51 | avatar : usuarioDaPublicacao.avatar 52 | }}; 53 | result.push(final); 54 | } 55 | } 56 | 57 | return res.status(200).json(result); 58 | } 59 | } 60 | return res.status(405).json({erro : 'Metodo informado nao e valido'}); 61 | }catch(e){ 62 | console.log(e); 63 | } 64 | return res.status(400).json({erro : 'Nao foi possivel obter o feed'}); 65 | } 66 | 67 | export default politicaCORS(validarTokenJWT(conectarMongoDB(feedEndpoint))); -------------------------------------------------------------------------------- /pages/api/like.ts: -------------------------------------------------------------------------------- 1 | import type { NextApiRequest, NextApiResponse } from "next"; 2 | import { conectarMongoDB } from "../../middlewares/conectarMongoDB"; 3 | import { politicaCORS } from "../../middlewares/politicaCORS"; 4 | import { validarTokenJWT } from "../../middlewares/validarTokenJWT"; 5 | import { PublicacaoModel } from "../../models/PublicacaoModel"; 6 | import { UsuarioModel } from "../../models/UsuarioModel"; 7 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 8 | 9 | const likeEndpoint 10 | = async (req : NextApiRequest, res : NextApiResponse) => { 11 | 12 | try { 13 | if(req.method === 'PUT'){ 14 | // id da Publicacao - checked 15 | const {id} = req?.query; 16 | const publicacao = await PublicacaoModel.findById(id); 17 | if(!publicacao){ 18 | return res.status(400).json({erro : 'Publicacao nao encontrada'}); 19 | } 20 | 21 | // id do usuario que ta curtindo a pub 22 | const {userId} = req?.query; 23 | const usuario = await UsuarioModel.findById(userId); 24 | if(!usuario){ 25 | return res.status(400).json({erro : 'Usuario nao encontrada'}); 26 | } 27 | 28 | const indexDoUsuarioNoLike = publicacao.likes.findIndex((e : any) => e.toString() === usuario._id.toString()); 29 | 30 | // se o index for > -1 sinal q ele ja curte a foto 31 | if(indexDoUsuarioNoLike != -1){ 32 | publicacao.likes.splice(indexDoUsuarioNoLike, 1); 33 | await PublicacaoModel.findByIdAndUpdate({_id : publicacao._id}, publicacao); 34 | return res.status(200).json({msg : 'Publicacao descurtida com sucesso'}); 35 | }else { 36 | // se o index for -1 sinal q ele nao curte a foto 37 | publicacao.likes.push(usuario._id); 38 | await PublicacaoModel.findByIdAndUpdate({_id : publicacao._id}, publicacao); 39 | return res.status(200).json({msg : 'Publicacao curtida com sucesso'}); 40 | } 41 | } 42 | 43 | return res.status(405).json({erro : 'Metodo informado nao e valido'}); 44 | }catch(e){ 45 | console.log(e); 46 | return res.status(500).json({erro : 'Ocorreu erro ao curtir/descurtir uma publicacao'}); 47 | } 48 | } 49 | 50 | export default politicaCORS(validarTokenJWT(conectarMongoDB(likeEndpoint))); -------------------------------------------------------------------------------- /pages/api/login.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse} from 'next'; 2 | import { conectarMongoDB } from '../../middlewares/conectarMongoDB'; 3 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 4 | import type {LoginResposta} from '../../types/LoginResposta'; 5 | import md5 from 'md5'; 6 | import { UsuarioModel } from '../../models/UsuarioModel'; 7 | import jwt from 'jsonwebtoken'; 8 | import { politicaCORS } from '../../middlewares/politicaCORS'; 9 | 10 | const endpointLogin = async ( 11 | req : NextApiRequest, 12 | res : NextApiResponse 13 | ) => { 14 | 15 | const {MINHA_CHAVE_JWT} = process.env; 16 | if(!MINHA_CHAVE_JWT){ 17 | return res.status(500).json({erro : 'ENV Jwt nao informada'}); 18 | } 19 | 20 | if(req.method === 'POST'){ 21 | const {login, senha} = req.body; 22 | 23 | const usuariosEncontrados = await UsuarioModel.find({email : login, senha : md5(senha)}); 24 | if(usuariosEncontrados && usuariosEncontrados.length > 0){ 25 | const usuarioEncotrado = usuariosEncontrados[0]; 26 | 27 | const token = jwt.sign({_id : usuarioEncotrado._id}, MINHA_CHAVE_JWT); 28 | return res.status(200).json({ 29 | nome : usuarioEncotrado.nome, 30 | email : usuarioEncotrado.email, 31 | token}); 32 | } 33 | return res.status(400).json({erro : 'Usuario ou senha nao encontrado'}); 34 | } 35 | return res.status(405).json({erro : 'Metodo informado nao e valido'}); 36 | } 37 | 38 | export default politicaCORS(conectarMongoDB(endpointLogin)); -------------------------------------------------------------------------------- /pages/api/pesquisa.ts: -------------------------------------------------------------------------------- 1 | import type { NextApiRequest, NextApiResponse } from 'next'; 2 | import { conectarMongoDB } from '../../middlewares/conectarMongoDB'; 3 | import { politicaCORS } from '../../middlewares/politicaCORS'; 4 | import { validarTokenJWT } from '../../middlewares/validarTokenJWT'; 5 | import { SeguidorModel } from '../../models/SeguidorModel'; 6 | import { UsuarioModel } from '../../models/UsuarioModel'; 7 | import type { RespostaPadraoMsg } from '../../types/RespostaPadraoMsg'; 8 | 9 | const pesquisaEndpoint 10 | = async (req: NextApiRequest, res: NextApiResponse) => { 11 | try { 12 | if (req.method === 'GET') { 13 | if (req?.query?.id) { 14 | const usuarioEncontrado = await UsuarioModel.findById(req?.query?.id); 15 | if (!usuarioEncontrado) { 16 | return res.status(400).json({ erro: 'Usuario nao encontrado' }); 17 | } 18 | 19 | const user = { 20 | senha: null, 21 | segueEsseUsuario: false, 22 | nome: usuarioEncontrado.nome, 23 | email: usuarioEncontrado.email, 24 | _id: usuarioEncontrado._id, 25 | avatar: usuarioEncontrado.avatar, 26 | seguidores: usuarioEncontrado.seguidores, 27 | seguindo: usuarioEncontrado.seguindo, 28 | publicacoes: usuarioEncontrado.publicacoes, 29 | } as any; 30 | 31 | const segueEsseUsuario = await SeguidorModel.find({ usuarioId: req?.query?.userId, usuarioSeguidoId: usuarioEncontrado._id }); 32 | if (segueEsseUsuario && segueEsseUsuario.length > 0) { 33 | user.segueEsseUsuario = true; 34 | } 35 | return res.status(200).json(user); 36 | } else { 37 | const { filtro } = req.query; 38 | if (!filtro || filtro.length < 2) { 39 | return res.status(400).json({ erro: 'Favor informar pelo menos 2 caracteres para a busca' }); 40 | } 41 | 42 | const usuariosEncontrados = await UsuarioModel.find({ 43 | $or: [{ nome: { $regex: filtro, $options: 'i' } }, 44 | //{ email : {$regex : filtro, $options: 'i'}} 45 | ] 46 | }); 47 | 48 | usuariosEncontrados.forEach(userFound => { 49 | userFound.senha = null 50 | }); 51 | 52 | return res.status(200).json(usuariosEncontrados); 53 | } 54 | } 55 | return res.status(405).json({ erro: 'Metodo informado nao e valido' }); 56 | } catch (e) { 57 | console.log(e); 58 | return res.status(500).json({ erro: 'Nao foi possivel buscar usuarios:' + e }); 59 | } 60 | } 61 | 62 | export default politicaCORS(validarTokenJWT(conectarMongoDB(pesquisaEndpoint))); -------------------------------------------------------------------------------- /pages/api/publicacao.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiResponse} from 'next'; 2 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 3 | import nc from 'next-connect'; 4 | import {updload, uploadImagemCosmic} from '../../services/uploadImagemCosmic'; 5 | import {conectarMongoDB} from '../../middlewares/conectarMongoDB'; 6 | import {validarTokenJWT} from '../../middlewares/validarTokenJWT'; 7 | import {PublicacaoModel} from '../../models/PublicacaoModel'; 8 | import {UsuarioModel} from '../../models/UsuarioModel'; 9 | import { politicaCORS } from '../../middlewares/politicaCORS'; 10 | 11 | const handler = nc() 12 | .use(updload.single('file')) 13 | .post(async (req : any, res : NextApiResponse) => { 14 | try{ 15 | const {userId} = req.query; 16 | const usuario = await UsuarioModel.findById(userId); 17 | if(!usuario){ 18 | return res.status(400).json({erro : 'Usuario nao encontrado'}); 19 | } 20 | 21 | if(!req || !req.body){ 22 | return res.status(400).json({erro : 'Parametros de entrada nao informados'}); 23 | } 24 | const {descricao} = req?.body; 25 | 26 | if(!descricao || descricao.length < 2){ 27 | return res.status(400).json({erro : 'Descricao nao e valida'}); 28 | } 29 | 30 | if(!req.file || !req.file.originalname){ 31 | return res.status(400).json({erro : 'Imagem e obrigatoria'}); 32 | } 33 | 34 | const image = await uploadImagemCosmic(req); 35 | const publicacao = { 36 | idUsuario : usuario._id, 37 | descricao, 38 | foto : image.media.url, 39 | data : new Date() 40 | } 41 | 42 | usuario.publicacoes++; 43 | await UsuarioModel.findByIdAndUpdate({_id : usuario._id}, usuario); 44 | 45 | await PublicacaoModel.create(publicacao); 46 | return res.status(200).json({msg : 'Publicacao criada com sucesso'}); 47 | }catch(e){ 48 | console.log(e); 49 | return res.status(400).json({erro : 'Erro ao cadastrar publicacao'}); 50 | } 51 | }); 52 | 53 | export const config = { 54 | api : { 55 | bodyParser : false 56 | } 57 | } 58 | 59 | export default politicaCORS(validarTokenJWT(conectarMongoDB(handler))); -------------------------------------------------------------------------------- /pages/api/seguir.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse} from 'next'; 2 | import { conectarMongoDB } from '../../middlewares/conectarMongoDB'; 3 | import { politicaCORS } from '../../middlewares/politicaCORS'; 4 | import { validarTokenJWT } from '../../middlewares/validarTokenJWT'; 5 | import { SeguidorModel } from '../../models/SeguidorModel'; 6 | import { UsuarioModel } from '../../models/UsuarioModel'; 7 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 8 | 9 | const endpointSeguir = 10 | async (req : NextApiRequest, res : NextApiResponse) => { 11 | try{ 12 | if(req.method === 'PUT'){ 13 | 14 | const {userId, id} = req?.query; 15 | 16 | // usuario logado/autenticado = quem esta fazendo as acoes 17 | const usuarioLogado = await UsuarioModel.findById(userId); 18 | if(!usuarioLogado){ 19 | return res.status(400).json({erro : 'Usuario logado nao encontrado'}); 20 | } 21 | 22 | // id do usuario e ser seguidor - query 23 | const usuarioASerSeguido = await UsuarioModel.findById(id); 24 | if(!usuarioASerSeguido){ 25 | return res.status(400).json({ erro : 'Usuario a ser seguido nao encontrado'}); 26 | } 27 | 28 | // buscar se EU LOGADO sigo ou nao esse usuario 29 | const euJaSigoEsseUsuario = await SeguidorModel 30 | .find({usuarioId: usuarioLogado._id, usuarioSeguidoId : usuarioASerSeguido._id}); 31 | if(euJaSigoEsseUsuario && euJaSigoEsseUsuario.length > 0){ 32 | // sinal que eu ja sigo esse usuario 33 | euJaSigoEsseUsuario.forEach(async(e : any) => 34 | await SeguidorModel.findByIdAndDelete({_id : e._id})); 35 | 36 | usuarioLogado.seguindo--; 37 | await UsuarioModel.findByIdAndUpdate({_id : usuarioLogado._id}, usuarioLogado); 38 | usuarioASerSeguido.seguidores--; 39 | await UsuarioModel.findByIdAndUpdate({_id : usuarioASerSeguido._id}, usuarioASerSeguido); 40 | 41 | return res.status(200).json({msg : 'Deixou de seguir o usuario com sucesso'}); 42 | }else{ 43 | // sinal q eu nao sigo esse usuario 44 | const seguidor = { 45 | usuarioId : usuarioLogado._id, 46 | usuarioSeguidoId : usuarioASerSeguido._id 47 | }; 48 | await SeguidorModel.create(seguidor); 49 | 50 | // adicionar um seguindo no usuario logado 51 | usuarioLogado.seguindo++; 52 | await UsuarioModel.findByIdAndUpdate({_id : usuarioLogado._id}, usuarioLogado); 53 | 54 | // adicionar um seguidor no usuario seguido 55 | usuarioASerSeguido.seguidores++; 56 | await UsuarioModel.findByIdAndUpdate({_id : usuarioASerSeguido._id}, usuarioASerSeguido); 57 | 58 | return res.status(200).json({msg : 'Usuario seguido com sucesso'}); 59 | } 60 | } 61 | 62 | return res.status(405).json({erro : 'Metodo informado nao existe'}); 63 | }catch(e){ 64 | console.log(e); 65 | return res.status(500).json({erro : 'Nao foi possivel seguir/deseguir o usuario informado'}); 66 | } 67 | } 68 | 69 | export default politicaCORS(validarTokenJWT(conectarMongoDB(endpointSeguir))); -------------------------------------------------------------------------------- /pages/api/usuario.ts: -------------------------------------------------------------------------------- 1 | import type {NextApiRequest, NextApiResponse} from 'next'; 2 | import type {RespostaPadraoMsg} from '../../types/RespostaPadraoMsg'; 3 | import {validarTokenJWT} from '../../middlewares/validarTokenJWT'; 4 | import {conectarMongoDB} from '../../middlewares/conectarMongoDB'; 5 | import { UsuarioModel } from '../../models/UsuarioModel'; 6 | import nc from 'next-connect'; 7 | import {updload, uploadImagemCosmic} from '../../services/uploadImagemCosmic'; 8 | import { politicaCORS } from '../../middlewares/politicaCORS'; 9 | 10 | const handler = nc() 11 | .use(updload.single('file')) 12 | .put(async(req : any, res : NextApiResponse) => { 13 | try{ 14 | const {userId} = req?.query; 15 | const usuario = await UsuarioModel.findById(userId); 16 | 17 | if(!usuario){ 18 | return res.status(400).json({erro : 'Usuario nao encontrado'}); 19 | } 20 | 21 | const {nome} = req?.body; 22 | if(nome && nome.length > 2){ 23 | usuario.nome = nome; 24 | } 25 | 26 | const {file} = req; 27 | if(file && file.originalname){ 28 | const image = await uploadImagemCosmic(req); 29 | if(image && image.media && image.media.url){ 30 | usuario.avatar = image.media.url; 31 | } 32 | } 33 | 34 | await UsuarioModel 35 | .findByIdAndUpdate({_id : usuario._id}, usuario); 36 | 37 | return res.status(200).json({msg : 'Usuario alterado com sucesos'}); 38 | }catch(e){ 39 | console.log(e); 40 | return res.status(400).json({erro : 'Nao foi possivel atualizar usuario:' + e}); 41 | } 42 | }) 43 | .get(async (req : NextApiRequest, res : NextApiResponse) => { 44 | try{ 45 | const {userId} = req?.query; 46 | const usuario = await UsuarioModel.findById(userId); 47 | console.log('usuario', usuario); 48 | usuario.senha = null; 49 | return res.status(200).json(usuario); 50 | }catch(e){ 51 | console.log(e); 52 | } 53 | 54 | return res.status(400).json({erro : 'Nao foi possivel obter dados do usuario'}) 55 | }); 56 | 57 | export const config = { 58 | api : { 59 | bodyParser : false 60 | } 61 | } 62 | 63 | export default politicaCORS(validarTokenJWT(conectarMongoDB(handler))); -------------------------------------------------------------------------------- /services/uploadImagemCosmic.ts: -------------------------------------------------------------------------------- 1 | import multer from "multer"; 2 | import cosmicjs from "cosmicjs"; 3 | 4 | const { 5 | CHAVE_GRAVACAO_AVATARES, 6 | CHAVE_GRAVACAO_PUBLICACOES, 7 | BUCKET_AVATARES, 8 | BUCKET_PUBLICACOES} = process.env; 9 | 10 | const Cosmic = cosmicjs(); 11 | const bucketAvatares = Cosmic.bucket({ 12 | slug: BUCKET_AVATARES, 13 | write_key: CHAVE_GRAVACAO_AVATARES 14 | }); 15 | 16 | const bucketPublicacoes = Cosmic.bucket({ 17 | slug: BUCKET_PUBLICACOES, 18 | write_key: CHAVE_GRAVACAO_PUBLICACOES 19 | }); 20 | 21 | const storage = multer.memoryStorage(); 22 | const updload = multer({storage : storage}); 23 | 24 | const uploadImagemCosmic = async(req : any) => { 25 | if(req?.file?.originalname){ 26 | 27 | if(!req.file.originalname.includes('.png') && 28 | !req.file.originalname.includes('.jpg') && 29 | !req.file.originalname.includes('.jpeg')){ 30 | throw new Error('Extensao da imagem invalida'); 31 | } 32 | 33 | const media_object = { 34 | originalname: req.file.originalname, 35 | buffer : req.file.buffer 36 | }; 37 | 38 | if(req.url && req.url.includes('publicacao')){ 39 | return await bucketPublicacoes.addMedia({media : media_object}); 40 | }else{ 41 | return await bucketAvatares.addMedia({media : media_object}); 42 | } 43 | } 44 | } 45 | 46 | export {updload, uploadImagemCosmic}; -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es5", 4 | "lib": ["dom", "dom.iterable", "esnext"], 5 | "allowJs": true, 6 | "skipLibCheck": true, 7 | "strict": true, 8 | "forceConsistentCasingInFileNames": true, 9 | "noEmit": true, 10 | "esModuleInterop": true, 11 | "module": "esnext", 12 | "moduleResolution": "node", 13 | "resolveJsonModule": true, 14 | "isolatedModules": true, 15 | "jsx": "preserve", 16 | "incremental": true 17 | }, 18 | "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"], 19 | "exclude": ["node_modules"] 20 | } 21 | -------------------------------------------------------------------------------- /types/CadastroRequisicao.ts: -------------------------------------------------------------------------------- 1 | export type CadastroRequisicao = { 2 | nome : string, 3 | email : string, 4 | senha : string 5 | } -------------------------------------------------------------------------------- /types/LoginResposta.ts: -------------------------------------------------------------------------------- 1 | export type LoginResposta = { 2 | nome : string, 3 | email : string, 4 | token : string 5 | } -------------------------------------------------------------------------------- /types/RespostaPadraoMsg.ts: -------------------------------------------------------------------------------- 1 | export type RespostaPadraoMsg ={ 2 | msg? : string, 3 | erro? : string 4 | } --------------------------------------------------------------------------------