├── .eslintignore ├── client ├── src │ ├── vite-env.d.ts │ ├── components │ │ ├── Error.tsx │ │ ├── Home.tsx │ │ ├── AddMovie.tsx │ │ ├── EditModal.tsx │ │ └── MovieDisplay.tsx │ ├── utils │ │ ├── types.ts │ │ └── sample-queries.ts │ ├── main.tsx │ ├── App.tsx │ ├── App.css │ ├── assets │ │ └── TroveQL ICON.svg │ └── index.css ├── tsconfig.node.json ├── vite.config.ts ├── tsconfig.json ├── package.json ├── index.html └── public │ └── vite.svg ├── server ├── .env ├── tsconfig.json ├── package.json ├── schema.js ├── resolvers.js ├── index.js ├── index.ts ├── data.js └── package-lock.json ├── database ├── config │ └── config.js └── models │ ├── index.js │ ├── actorModel.js │ ├── movieModel.js │ ├── watchlistModel.js │ └── movie_actorModel.js ├── .sequelizerc ├── .gitignore ├── .eslintrc.json ├── package.json ├── README.md └── assets └── TroveQL-black.svg /.eslintignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | /server/index.js -------------------------------------------------------------------------------- /client/src/vite-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /server/.env: -------------------------------------------------------------------------------- 1 | PG_URI="postgres://gvemrzdz:Y4VyUaXsnS_h7tttHnZQOjCi2yk5uifi@mahmud.db.elephantsql.com/gvemrzdz" 2 | NODE_ENV="development" -------------------------------------------------------------------------------- /database/config/config.js: -------------------------------------------------------------------------------- 1 | const config = { 2 | development: { 3 | use_env_variable: 'PG_URI', 4 | dialect: 'postgresql', 5 | } 6 | }; 7 | 8 | module.exports = config; -------------------------------------------------------------------------------- /client/src/components/Error.tsx: -------------------------------------------------------------------------------- 1 | function Error() { 2 | return ( 3 |
4 |

Oops!

5 |

This page does not exist.

6 |
7 | ) 8 | } 9 | 10 | export default Error; -------------------------------------------------------------------------------- /client/tsconfig.node.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "module": "ESNext", 5 | "moduleResolution": "Node", 6 | "allowSyntheticDefaultImports": true 7 | }, 8 | "include": ["vite.config.ts"] 9 | } 10 | -------------------------------------------------------------------------------- /client/src/utils/types.ts: -------------------------------------------------------------------------------- 1 | export type Actor = { 2 | id: number, 3 | name: string 4 | } 5 | 6 | 7 | export type Movie = { 8 | id: number, 9 | title: string, 10 | genre: string, 11 | year: number, 12 | actors: Actor[] 13 | }; 14 | 15 | export type GetMoviesData = { 16 | data: { 17 | movies: Movie[] 18 | } 19 | } -------------------------------------------------------------------------------- /.sequelizerc: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | require('dotenv').config(); 4 | 5 | const path = require('path') 6 | module.exports = { 7 | config: path.resolve('./database/config', 'config.js'), 8 | 'models-path': path.resolve('./database/models'), 9 | 'seeders-path': path.resolve('./database/seeders'), 10 | 'migrations-path': path.resolve('./database/migrations'), 11 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | -------------------------------------------------------------------------------- /client/src/main.tsx: -------------------------------------------------------------------------------- 1 | import 'vite/modulepreload-polyfill' 2 | import React from 'react' 3 | import ReactDOM from 'react-dom/client' 4 | import { BrowserRouter as Router} from "react-router-dom" 5 | import App from './App' 6 | 7 | // Import css stylesheet 8 | import './index.css' 9 | 10 | ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render( 11 | 12 | 13 | 14 | 15 | 16 | ) -------------------------------------------------------------------------------- /database/models/index.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const Sequelize = require('sequelize'); 3 | const process = require('process'); 4 | const env = process.env.NODE_ENV || 'development'; 5 | const config = require(__dirname + '/../config/config.js')[env]; 6 | 7 | let sequelize; 8 | if (config.use_env_variable) { 9 | sequelize = new Sequelize(process.env[config.use_env_variable], config); 10 | } else { 11 | sequelize = new Sequelize(config.database, config.username, config.password, config); 12 | } 13 | 14 | module.exports = sequelize; 15 | -------------------------------------------------------------------------------- /server/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ESNext", 4 | "useDefineForClassFields": true, 5 | "allowJs": false, 6 | "skipLibCheck": true, 7 | "esModuleInterop": true, 8 | "allowSyntheticDefaultImports": true, 9 | "strict": true, 10 | "forceConsistentCasingInFileNames": true, 11 | "module": "ESNext", 12 | "moduleResolution": "Node", 13 | "resolveJsonModule": true, 14 | "isolatedModules": true, 15 | "noEmit": true, 16 | "noImplicitAny": true, 17 | "watch": true 18 | }, 19 | "include": ["index.ts"] 20 | } 21 | -------------------------------------------------------------------------------- /client/vite.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()], 7 | build: { 8 | // generate manifest.json in outDir 9 | manifest: true, 10 | rollupOptions: { 11 | // overwrite default .html entry 12 | input: '/src/main.tsx', 13 | }, 14 | }, 15 | server: { 16 | port: 8080, 17 | proxy: { 18 | '/troveql': 'http://localhost:4000/troveql', 19 | '/reset': 'http://localhost:4000/reset', 20 | } 21 | } 22 | }) 23 | -------------------------------------------------------------------------------- /client/src/App.tsx: -------------------------------------------------------------------------------- 1 | import './App.css' 2 | import { Route, Routes } from "react-router-dom" 3 | import Home from './components/Home' 4 | import MovieDisplay from './components/MovieDisplay' 5 | import Error from './components/Error' 6 | 7 | function App() { 8 | 9 | return ( 10 |
11 |

TROVEQL DEMO

12 | 13 | } /> 14 | } /> 15 | } /> 16 | 17 |
18 | ) 19 | } 20 | 21 | export default App; 22 | -------------------------------------------------------------------------------- /client/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ESNext", 4 | "useDefineForClassFields": true, 5 | "lib": ["DOM", "DOM.Iterable", "ESNext"], 6 | "allowJs": false, 7 | "skipLibCheck": true, 8 | "esModuleInterop": false, 9 | "allowSyntheticDefaultImports": true, 10 | "strict": true, 11 | "forceConsistentCasingInFileNames": true, 12 | "module": "ESNext", 13 | "moduleResolution": "Node", 14 | "resolveJsonModule": true, 15 | "isolatedModules": true, 16 | "noEmit": true, 17 | "jsx": "react-jsx" 18 | }, 19 | "include": ["src"], 20 | "references": [{ "path": "./tsconfig.node.json" }] 21 | } 22 | -------------------------------------------------------------------------------- /client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "troveql-demo", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "tsc && vite build", 9 | "preview": "vite preview" 10 | }, 11 | "dependencies": { 12 | "react": "^18.2.0", 13 | "react-dom": "^18.2.0", 14 | "react-router-dom": "^6.9.0", 15 | "sass": "^1.60.0", 16 | "@react-navigation/native": "^6.1.6" 17 | }, 18 | "devDependencies": { 19 | "@types/react": "^18.0.28", 20 | "@types/react-dom": "^18.0.11", 21 | "@vitejs/plugin-react": "^3.1.0", 22 | "typescript": "^4.9.3", 23 | "vite": "^4.2.0" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /database/models/actorModel.js: -------------------------------------------------------------------------------- 1 | const sequelize = require('./index'); 2 | const { DataTypes } = require('sequelize'); 3 | 4 | // create Actor model 5 | const Actor = sequelize.define("actor", { 6 | id: { 7 | type: DataTypes.INTEGER, 8 | autoIncrement: true, 9 | allowNull: false, 10 | primaryKey: true, 11 | }, 12 | 13 | name: { 14 | type: DataTypes.STRING, 15 | allowNull: false 16 | }, 17 | 18 | gender: { 19 | type: DataTypes.STRING, 20 | allowNull: true, 21 | }, 22 | 23 | place_of_birth: { 24 | type: DataTypes.STRING, 25 | allowNull: true, 26 | }, 27 | }); 28 | 29 | // UNCOMMENT THE FOLLOWING CODE to call sync method on model to create/update table 30 | Actor 31 | .sync({ force: false }) 32 | 33 | module.exports = Actor; -------------------------------------------------------------------------------- /server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "dev": "tsc index.ts && nodemon index.js", 8 | "start": "tsc index.ts && node index.js" 9 | }, 10 | "keywords": [], 11 | "author": "", 12 | "license": "ISC", 13 | "dependencies": { 14 | "@graphql-tools/schema": "^9.0.17", 15 | "cors": "^2.8.5", 16 | "dotenv": "^16.0.3", 17 | "dotenv-cli": "^7.2.1", 18 | "express": "^4.18.2", 19 | "express-graphql": "^0.12.0", 20 | "troveql": "^0.1.7" 21 | }, 22 | "devDependencies": { 23 | "@types/express": "^4.17.17", 24 | "nodemon": "^2.0.21", 25 | "sequelize": "^6.31.0", 26 | "tsc-watch": "^6.0.0", 27 | "typescript": "^5.0.2" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /client/src/App.css: -------------------------------------------------------------------------------- 1 | #root { 2 | /* max-width: 1280px; */ 3 | margin: 0 auto; 4 | padding: 2rem; 5 | text-align: center; 6 | } 7 | 8 | .logo { 9 | height: 6em; 10 | padding: 1.5em; 11 | will-change: filter; 12 | transition: filter 300ms; 13 | } 14 | .logo:hover { 15 | filter: drop-shadow(0 0 2em #646cffaa); 16 | } 17 | .logo.react:hover { 18 | filter: drop-shadow(0 0 2em #61dafbaa); 19 | } 20 | 21 | @keyframes logo-spin { 22 | from { 23 | transform: rotate(0deg); 24 | } 25 | to { 26 | transform: rotate(360deg); 27 | } 28 | } 29 | 30 | @media (prefers-reduced-motion: no-preference) { 31 | a:nth-of-type(2) .logo { 32 | animation: logo-spin infinite 20s linear; 33 | } 34 | } 35 | 36 | .card { 37 | padding: 2em; 38 | } 39 | 40 | .read-the-docs { 41 | color: #888; 42 | } 43 | 44 | -------------------------------------------------------------------------------- /database/models/movieModel.js: -------------------------------------------------------------------------------- 1 | // import sequelize instance 2 | const sequelize = require('./index'); 3 | // import Constructors for model creation 4 | const { DataTypes } = require('sequelize'); 5 | 6 | // create Movie model 7 | const Movie = sequelize.define("movie", { 8 | id: { 9 | type: DataTypes.INTEGER, 10 | autoIncrement: true, 11 | allowNull: false, 12 | primaryKey: true, 13 | }, 14 | 15 | title: { 16 | type: DataTypes.STRING, 17 | allowNull: false, 18 | }, 19 | 20 | genre: { 21 | type: DataTypes.STRING, 22 | allowNull: true, 23 | }, 24 | 25 | year: { 26 | type: DataTypes.INTEGER, 27 | allowNull: true, 28 | }, 29 | }); 30 | 31 | // UNCOMMENT THE FOLLOWING CODE to call sync method on model to create/update table 32 | Movie 33 | .sync({ force: false }) 34 | 35 | module.exports = Movie; 36 | -------------------------------------------------------------------------------- /client/src/components/Home.tsx: -------------------------------------------------------------------------------- 1 | import { useEffect, useRef } from 'react'; 2 | import { useNavigate } from "react-router-dom"; 3 | 4 | function Home() { 5 | const navigate = useNavigate(); 6 | const dataFetchedRef = useRef(false); 7 | 8 | useEffect(() => { 9 | if (dataFetchedRef.current) { 10 | return; 11 | } else { 12 | dataFetchedRef.current = true; 13 | fetch('/reset', { 14 | method: 'POST', 15 | headers: { 16 | 'Content-Type': 'application/json', 17 | } 18 | }) 19 | .catch((err) => console.log('Error resetting movies in the database: ', err)); 20 | } 21 | }, []); 22 | 23 | return ( 24 |
25 | 26 |
27 | ) 28 | } 29 | 30 | export default Home; -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "browser": true, 4 | "commonjs": true, 5 | "es2021": true 6 | }, 7 | "extends": [ 8 | "eslint:recommended", 9 | "plugin:@typescript-eslint/recommended" 10 | ], 11 | "overrides": [ 12 | { 13 | "files": ["*.js"], 14 | "rules": { 15 | "@typescript-eslint/no-var-requires": "off" 16 | } 17 | } 18 | ], 19 | "parser": "@typescript-eslint/parser", 20 | "parserOptions": { 21 | "ecmaVersion": "latest", 22 | "sourceType": "module" 23 | }, 24 | "plugins": [ 25 | "react", 26 | "@typescript-eslint" 27 | ], 28 | "rules": { 29 | "@typescript-eslint/no-unused-vars": "warn", 30 | "no-console": "warn", 31 | "quotes": [ 32 | "warn", 33 | "single" 34 | ] 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /client/src/utils/sample-queries.ts: -------------------------------------------------------------------------------- 1 | import { Query } from './types'; 2 | 3 | const queries: Query = { 4 | getMovies: `query { 5 | movies { 6 | id 7 | title 8 | } 9 | } 10 | `, 11 | getMovieDetails: `query ($id: ID) { 12 | movie(id: $id) { 13 | id 14 | title 15 | genre 16 | year 17 | actors 18 | { 19 | name 20 | } 21 | } 22 | }`, 23 | addMovie: `mutation CreateMovie($title: String) { 24 | createMovie(title: $title) { 25 | id 26 | title 27 | } 28 | }`, 29 | 30 | deleteMovie: `mutation DeleteMovie($id: ID) { 31 | deleteMovie(id: $id) { 32 | id 33 | title 34 | } 35 | }`, 36 | editMovie: `mutation EditMovie($id: ID, $title: String) { 37 | editMovie(id: $id, title: $title) { 38 | id 39 | title 40 | } 41 | }` 42 | }; 43 | 44 | export default queries; -------------------------------------------------------------------------------- /database/models/watchlistModel.js: -------------------------------------------------------------------------------- 1 | // import sequelize instance 2 | const sequelize = require('../db_connect'); 3 | // import Constructors for model creation 4 | const { DataTypes } = require('sequelize'); 5 | // import movieModel to associate foreign key 6 | const Movie = require('./movieModel'); 7 | 8 | // create Watchlist model 9 | const Watchlist = sequelize.define('watchlist', { 10 | id: { 11 | type: DataTypes.INTEGER, 12 | autoIncrement: true, 13 | allowNull: false, 14 | primaryKey: true, 15 | }, 16 | 17 | movie_id: { 18 | type: DataTypes.INTEGER, 19 | allowNull: false 20 | }, 21 | 22 | watched: { 23 | type: DataTypes.BOOLEAN, 24 | allowNull: false, 25 | defaultValue: false 26 | } 27 | }); 28 | 29 | // associate movie_id with movieModel's movie_id 30 | Watchlist.belongsTo(Movie, {foreignKey: 'movie_id'}); 31 | 32 | // UNCOMMENT THE FOLLOWING CODE to call sync method on model to create/update table 33 | Watchlist 34 | .sync({ force: false }) 35 | 36 | module.exports = Watchlist; 37 | -------------------------------------------------------------------------------- /client/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | My Demo App 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 23 | 24 | 25 | 26 | 27 | 28 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "dependencies": { 3 | "concurrently": "^7.6.0", 4 | "dotenv": "^16.0.3", 5 | "path": "^0.12.7", 6 | "pg": "^8.10.0", 7 | "pg-hstore": "^2.3.4", 8 | "sequelize": "^6.29.3", 9 | "sequelize-cli": "^6.6.0" 10 | }, 11 | "scripts": { 12 | "server": "cd ./server && npm start", 13 | "client": "cd ./client && npm run dev", 14 | "prestart": "cd ./server && npm install && cd .. && cd ./client && npm install && cd .. && npm install", 15 | "start": "concurrently \"cd ./server && npm start\" \"cd ./client && npm run dev\"", 16 | "lint": "eslint ." 17 | }, 18 | "devDependencies": { 19 | "@typescript-eslint/eslint-plugin": "^5.58.0", 20 | "@typescript-eslint/parser": "^5.58.0", 21 | "dotenv-cli": "^7.2.1", 22 | "eslint": "^8.38.0", 23 | "eslint-config-standard-with-typescript": "^34.0.1", 24 | "eslint-plugin-import": "^2.27.5", 25 | "eslint-plugin-n": "^15.7.0", 26 | "eslint-plugin-promise": "^6.1.1", 27 | "eslint-plugin-react": "^7.32.2", 28 | "eslint-plugin-react-hooks": "^4.6.0", 29 | "nodemon": "^2.0.21", 30 | "typescript": "^5.0.4" 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /server/schema.js: -------------------------------------------------------------------------------- 1 | const { makeExecutableSchema } = require('@graphql-tools/schema'); 2 | const { resolvers } = require('./resolvers'); 3 | 4 | // Clients can execute a query named movies and the server will return an array of zero or more Movies 5 | const typeDefs = `#graphql 6 | # "Movie" is a type that lets clients query the API by movie title (required) 7 | type Movie { 8 | id: ID! 9 | title: String! 10 | genre: String 11 | year: Int 12 | actors: [Actor] 13 | } 14 | 15 | type Actor { 16 | id: ID! 17 | name: String! 18 | gender: String 19 | place_of_birth: String 20 | movies: [Movie] 21 | } 22 | 23 | # The "Query" type lists all the ways clients can query the GraphQL API and the return type for each 24 | # The "movie" query returns an array of zero or more Movie objects 25 | type Query { 26 | movies: [Movie!]! 27 | movie(id: ID): Movie! 28 | actors: [Actor!]! 29 | } 30 | 31 | type Mutation { 32 | createMovie(title: String): Movie! 33 | deleteMovie(id: ID): Movie! 34 | editMovie(id:ID, title: String): Movie! 35 | } 36 | `; 37 | 38 | const schema = makeExecutableSchema({ typeDefs, resolvers }); 39 | 40 | module.exports = { schema }; -------------------------------------------------------------------------------- /server/resolvers.js: -------------------------------------------------------------------------------- 1 | const { 2 | getMovies, 3 | getMovie, 4 | getActorsFromMovieID, 5 | addMovie, 6 | deleteMovie, 7 | editMovie, 8 | } = require('./data'); 9 | 10 | // Resolvers describe what the server returns to the client for a specific query 11 | const resolvers = { 12 | Mutation: { 13 | createMovie: async (obj, args) => { 14 | const result = await addMovie(args.title); 15 | return result; 16 | }, 17 | 18 | deleteMovie: async (obj, args) => { 19 | const result = await deleteMovie(args.id); 20 | return result; 21 | }, 22 | 23 | editMovie: async (obj, args) => { 24 | const result = await editMovie(args.id, args.title); 25 | return result; 26 | } 27 | }, 28 | Query: { 29 | movies: async () => { 30 | const movies = await getMovies(); 31 | return movies; 32 | }, 33 | movie: async (obj, args, context, info) => { 34 | const result = await getMovie(args.id); 35 | return result; 36 | } 37 | }, 38 | Movie: { 39 | actors: async (parent) => { 40 | const result = await getActorsFromMovieID(parent.id); 41 | return result; 42 | }, 43 | }, 44 | }; 45 | 46 | module.exports = { resolvers }; 47 | -------------------------------------------------------------------------------- /database/models/movie_actorModel.js: -------------------------------------------------------------------------------- 1 | // import sequelize instance 2 | const sequelize = require('./index'); 3 | // import Constructors for model creation 4 | const { DataTypes } = require('sequelize'); 5 | // import movieModel to associate foreign key 6 | const Movie = require('./movieModel'); 7 | const Actor = require('./actorModel'); 8 | 9 | // create ActorinMovies model as join table 10 | const ActorinMovies = sequelize.define("movie_actor", { 11 | id: { 12 | type: DataTypes.INTEGER, 13 | autoIncrement: true, 14 | allowNull: false, 15 | primaryKey: true, 16 | }, 17 | 18 | movie_id: { 19 | type: DataTypes.INTEGER, 20 | allowNull: true, 21 | }, 22 | 23 | actor_id: { 24 | type: DataTypes.INTEGER, 25 | allowNull: true, 26 | } 27 | }); 28 | 29 | // associate movie_id with movieModel's id 30 | // associate actor_id with actorModel's id 31 | ActorinMovies.belongsTo(Movie, {foreignKey: 'movie_id'}); 32 | ActorinMovies.belongsTo(Actor, {foreignKey: 'actor_id'}); 33 | 34 | // create many to many connections to associate join table with movie table and actor table 35 | Actor.belongsToMany(Movie, { through: ActorinMovies, foreignKey: 'actor_id' }); 36 | Movie.belongsToMany(Actor, { through: ActorinMovies, foreignKey: 'movie_id' }); 37 | 38 | // UNCOMMENT THE FOLLOWING CODE to call sync method on model to create/update table 39 | ActorinMovies 40 | .sync({ force: false }) 41 | 42 | module.exports = ActorinMovies; 43 | -------------------------------------------------------------------------------- /client/public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /client/src/components/AddMovie.tsx: -------------------------------------------------------------------------------- 1 | import React, { useState } from 'react'; 2 | import queries from '../utils/sample-queries'; 3 | 4 | function AddMovie(props: any) { 5 | const [movieTitle, setMovieTitle] = useState(''); 6 | 7 | function handleSubmit(e: React.FormEvent) { 8 | e.preventDefault(); 9 | const query: string = queries.addMovie; 10 | 11 | // validate if input has value 12 | if (!movieTitle) { 13 | alert('Please fill out movie title'); 14 | return; 15 | } 16 | 17 | // submit the form data 18 | fetch('/troveql', { 19 | method: 'POST', 20 | headers: { 21 | 'Content-Type': 'application/json', 22 | }, 23 | body: JSON.stringify({ 24 | query, 25 | variables: { title: movieTitle }, 26 | }), 27 | }) 28 | .then((response) => response.json()) 29 | .then((data) => { 30 | props.setMovies([...props.movies, data.data.createMovie]); 31 | setMovieTitle(''); 32 | return; 33 | }) 34 | .catch((err) => console.log('Error adding a movie: ', err)); 35 | } 36 | 37 | function handleInputChange(e: React.ChangeEvent) { 38 | const title = e.currentTarget.value; 39 | setMovieTitle(title); 40 | } 41 | 42 | return ( 43 |
44 |
45 | 46 | 53 | 54 |
55 |
56 | ); 57 | } 58 | 59 | export default AddMovie; 60 | -------------------------------------------------------------------------------- /client/src/assets/TroveQL ICON.svg: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | -------------------------------------------------------------------------------- /client/src/components/EditModal.tsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import { Movie } from '../utils/types'; 3 | import queries from '../utils/sample-queries'; 4 | 5 | function EditModal(props:any): JSX.Element { 6 | 7 | let newTitle = React.useRef('') 8 | 9 | function updateNewTitle(e: React.ChangeEvent){ 10 | newTitle.current = e.target.value; 11 | } 12 | 13 | let title: string = ''; 14 | props.movies.forEach((movie: Movie) => { 15 | if (movie.id === props.modal.movieId) title = movie.title 16 | }) 17 | 18 | 19 | function onAccept(e: React.MouseEvent){ 20 | props.setModal({display: false, movieId: null}) 21 | const movieId = props.modal.movieId; 22 | const query: string = queries.editMovie; 23 | const variables = { id: Number(movieId), title: newTitle.current }; 24 | 25 | fetch(`/troveql`, { 26 | method: 'POST', 27 | headers: { 28 | 'Content-Type': 'application/json', 29 | }, 30 | body: JSON.stringify({ 31 | query, 32 | variables, 33 | }), 34 | }) 35 | .then((response) => { 36 | if (response.ok) return response.json(); 37 | else console.log('Error editing a movie: response not OK'); 38 | }) 39 | .then((data) => { 40 | props.setMovies((prevMovies: Movie[]) => { 41 | const updatedMovies: Movie[] = []; 42 | prevMovies.forEach((movie: Movie)=>{ 43 | if (movie.id === movieId) updatedMovies.push(data.data.editMovie) 44 | else updatedMovies.push(movie) 45 | }) 46 | return updatedMovies; 47 | }); 48 | }) 49 | .catch((err) => console.log('Error editing a movie: ', err)); 50 | } 51 | 52 | function onCancel(e: React.MouseEvent) { 53 | props.setModal({display: false, movieId: null}) 54 | } 55 | 56 | return ( 57 |
58 |

EDIT MOVIE

59 | 68 |
69 | 70 | 71 |
72 |
73 | ); 74 | } 75 | 76 | export default EditModal; -------------------------------------------------------------------------------- /server/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | Object.defineProperty(exports, "__esModule", { value: true }); 3 | var express = require('express'); 4 | var graphqlHTTP = require('express-graphql').graphqlHTTP; 5 | var cors = require('cors'); 6 | require('dotenv').config(); 7 | var app = express(); 8 | var PORT = 4000; 9 | app.use(cors()); 10 | app.use(express.json()); 11 | app.use(express.urlencoded({ extended: true })); 12 | // The TroveQLCache middleware function requires 2 arguments with an addition 2 optional arguments: 13 | // (1) size for the cache 14 | // (2) your server's graphQL URL endpoint 15 | // (3) optional - boolean for if you want to use TM (defaults to false but if 'true' will need to add /trovemetrics route too) 16 | // (4) optional - object where the key is the name of your graphQL mutation query and the value is a string of the object Type it mutates 17 | var TroveQLCache = require('troveql').TroveQLCache; 18 | var mutations = { 19 | createMovie: 'movie', 20 | deleteMovie: 'movie', 21 | editMovie: 'movie' 22 | }; 23 | var cache = new TroveQLCache(5, 'http://localhost:4000/graphql', true, mutations); 24 | app.use('/troveql', cache.queryCache, function (req, res) { return res.status(200).json(res.locals.value); }); 25 | //do we want to just add the troveMetrics middleware to the /troveql endpoint? 26 | app.use('/trovemetrics', cache.troveMetrics, function (req, res) { return res.status(200).json(res.locals.message); }); 27 | var resetMovies = require('./data').resetMovies; 28 | // reset the db whenever the app initially loads 29 | app.use('/reset', 30 | //middleware function that uses resetMovie from data.js 31 | function (req, res, next) { 32 | resetMovies(); 33 | next(); 34 | }, 35 | //clear the cache in TM once we reset all the movies in the db 36 | cache.troveMetrics, function (req, res) { return res.status(200).json('resetMovies function run!'); }); 37 | var schema = require('./schema').schema; 38 | var resolvers = require('./resolvers').resolvers; 39 | app.use('/graphql', graphqlHTTP({ 40 | schema: schema, 41 | rootValue: resolvers, 42 | graphiql: true 43 | })); 44 | app.use('/', function (err, req, res, next) { 45 | var defaultErr = { 46 | log: 'Express error handler caught unknown middleware error', 47 | status: 400, 48 | message: { err: 'An error occurred' }, 49 | }; 50 | var errorObj = Object.assign({}, defaultErr, err); 51 | console.log(errorObj.log); 52 | return res.status(errorObj.status).json(errorObj.message); 53 | }); 54 | app.listen(PORT, function () { return console.log("Express Server ready at http://localhost:".concat(PORT)); }); 55 | -------------------------------------------------------------------------------- /server/index.ts: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const { graphqlHTTP } = require('express-graphql'); 3 | const cors = require('cors'); 4 | require('dotenv').config(); 5 | 6 | const app = express(); 7 | const PORT = 4000; 8 | 9 | app.use(cors()); 10 | app.use(express.json()); 11 | app.use(express.urlencoded({ extended: true })); 12 | 13 | // Declare/import typescript tyeps 14 | import { Request, Response, NextFunction} from 'express'; 15 | 16 | type ServerError = { 17 | log: string, 18 | status: number, 19 | message: { err: string }, 20 | }; 21 | 22 | 23 | // The TroveQLCache middleware function requires 2 arguments with an addition 2 optional arguments: 24 | // (1) size for the cache 25 | // (2) your server's graphQL URL endpoint 26 | // (3) optional - boolean for if you want to use TM (defaults to false but if 'true' will need to add /trovemetrics route too) 27 | // (4) optional - object where the key is the name of your graphQL mutation query and the value is a string of the object Type it mutates 28 | const { TroveQLCache } = require('troveql'); 29 | const mutations = { 30 | createMovie: 'movie', 31 | deleteMovie: 'movie', 32 | editMovie: 'movie' 33 | }; 34 | const cache = new TroveQLCache(5, 'http://localhost:4000/graphql', true, mutations); 35 | app.use('/troveql', 36 | cache.queryCache, 37 | (req: Request, res: Response) => res.status(200).json(res.locals.value) 38 | ); 39 | //do we want to just add the troveMetrics middleware to the /troveql endpoint? 40 | app.use('/trovemetrics', 41 | cache.troveMetrics, 42 | (req: Request, res: Response) => res.status(200).json(res.locals.message) 43 | ); 44 | 45 | const { resetMovies } = require('./data'); 46 | // reset the db whenever the app initially loads 47 | app.use('/reset', 48 | //middleware function that uses resetMovie from data.js 49 | (req: Request, res: Response, next: NextFunction) => { 50 | resetMovies(); 51 | next(); 52 | }, 53 | //clear the cache in TM once we reset all the movies in the db 54 | cache.troveMetrics, 55 | (req: Request, res: Response) => res.status(200).json('resetMovies function run!') 56 | ); 57 | 58 | const { schema } = require('./schema'); 59 | const { resolvers } = require('./resolvers'); 60 | 61 | app.use('/graphql', 62 | graphqlHTTP({ 63 | schema: schema, 64 | rootValue: resolvers, 65 | graphiql: true 66 | }) 67 | ); 68 | 69 | app.use('/', (err: ServerError, req: Request, res: Response, next: NextFunction) => { 70 | const defaultErr: ServerError = { 71 | log: 'Express error handler caught unknown middleware error', 72 | status: 400, 73 | message: { err: 'An error occurred' }, 74 | }; 75 | const errorObj = Object.assign({}, defaultErr, err); 76 | console.log(errorObj.log); 77 | return res.status(errorObj.status).json(errorObj.message); 78 | }) 79 | 80 | 81 | app.listen(PORT, () => console.log(`Express Server ready at http://localhost:${PORT}`)); 82 | -------------------------------------------------------------------------------- /client/src/index.css: -------------------------------------------------------------------------------- 1 | :root { 2 | font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif; 3 | line-height: 1.5; 4 | font-weight: 400; 5 | 6 | color-scheme: light dark; 7 | color: rgba(255, 255, 255, 0.87); 8 | background-color: #242424; 9 | 10 | font-synthesis: none; 11 | text-rendering: optimizeLegibility; 12 | -webkit-font-smoothing: antialiased; 13 | -moz-osx-font-smoothing: grayscale; 14 | -webkit-text-size-adjust: 100%; 15 | } 16 | 17 | a { 18 | font-weight: 500; 19 | color: #646cff; 20 | text-decoration: inherit; 21 | } 22 | a:hover { 23 | color: #535bf2; 24 | } 25 | 26 | h3 { 27 | margin: .2rem; 28 | } 29 | 30 | body { 31 | margin: 0; 32 | display: flex; 33 | place-items: center; 34 | min-width: 320px; 35 | min-height: 100vh; 36 | } 37 | 38 | .moviedisplay-container { 39 | display: flex; 40 | align-items: flex-start; 41 | } 42 | 43 | .movie-list { 44 | border-radius: 5%; 45 | margin-left: 4em; 46 | } 47 | 48 | .movie-list li { 49 | display: flex; 50 | justify-content:space-between; 51 | align-items: center; 52 | } 53 | 54 | .movie-details { 55 | position: sticky; 56 | top: 25%; 57 | background-color:#1a1a1a; 58 | margin: 2em 2em 0 4em; 59 | border-radius: 5%; 60 | } 61 | 62 | .movie-details p { 63 | margin: 2em; 64 | color: white; 65 | } 66 | 67 | 68 | h1 { 69 | font-size: 3.2em; 70 | line-height: 1.1; 71 | } 72 | 73 | li { 74 | list-style: none; 75 | } 76 | 77 | button { 78 | border-radius: 8px; 79 | border: 1px solid transparent; 80 | padding: 0.6em 1.2em; 81 | font-size: 1em; 82 | font-weight: 500; 83 | font-family: inherit; 84 | background-color: #1a1a1a; 85 | cursor: pointer; 86 | transition: border-color 0.25s; 87 | margin: .2rem; 88 | } 89 | button:hover { 90 | border-color: #646cff; 91 | } 92 | button:focus, 93 | button:focus-visible { 94 | outline: 4px auto -webkit-focus-ring-color; 95 | } 96 | 97 | @media (prefers-color-scheme: light) { 98 | :root { 99 | color: #213547; 100 | background-color: #ffffff; 101 | } 102 | a:hover { 103 | color: #747bff; 104 | } 105 | button { 106 | background-color: #f9f9f9; 107 | } 108 | } 109 | 110 | .modal { 111 | position: fixed; 112 | top: 50%; 113 | left: 50%; 114 | transform: translate(-50%, -50%); 115 | width: 15rem; 116 | border: 1px solid white; 117 | border-radius: 8px; 118 | z-index: 999; 119 | background-color: #242424; 120 | display: flex; 121 | flex-direction:column; 122 | gap: .5rem; 123 | justify-content: center; 124 | padding: 2rem; 125 | } 126 | 127 | #overlay { 128 | position: fixed; 129 | top: 0; 130 | right: 0; 131 | bottom: 0; 132 | left: 0; 133 | z-index: 998; 134 | background: rgba(0, 0, 0, 0.3); 135 | } 136 | 137 | .small-input { 138 | height: 1.5rem; 139 | width: 10rem; 140 | } 141 | 142 | .edit-title-label { 143 | gap: .5rem; 144 | display: flex; 145 | align-items: center; 146 | justify-content: center; 147 | margin: .2rem; 148 | } -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |
2 | 3 |

TroveQL DEMO APP

4 |

TroveQL Demo is a simple web app with a GraphQL API on its Express.js server using the TroveQL cache library to showcase TroveQL and its performance metrics desktop application, TroveMetrics, in action.

5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | ## Get Started 22 | #### Clone this repository 23 | ```bash 24 | git clone https://github.com/oslabs-beta/troveql-demo.git 25 | ``` 26 | #### Set up a PostgreSQL database using ElephantSQL 27 | 1. Go to [ElephantSQL](https://www.elephantsql.com/), sign in or register for an account, and create a new database instance. Select the free tier as 'Tiny Turtle'. The instance's name and datacenter are up to you. 28 | 2. Copy your new database instance's URL from the DETAILS tab. 29 | 3. Check that you have [PostgresQL](https://www.postgresql.org/download/) installed. You can run `psql --version` on your command line to check. 30 | 31 | #### Set up your .env file 32 | 1. From the root directory of the Demo App, navigate to the /server folder. 33 | 2. Create a .env file in the server directory and add the following: 34 | ```javascript 35 | PG_URI=//insert your postgresql URI here 36 | ``` 37 | 38 | #### Download TroveMetrics 39 | Now go to the TroveQL website and download the desktop application for your OS (macOS, Windows, Linux). 40 | 41 | #### Run the demo 42 | 1. Open your downloaded TroveMetrics desktop application. 43 | 2. Next, install all the dependencies for the Demo App by running `npm run prestart` on your command line in the root folder. 44 | 3. Finally, run `npm start` from the root directory to start the Demo App on http://localhost:8080/. 45 | 4. Click around and see the TroveQL cache in action from TroveMetrics! (NOTE: If you are seeing proxy errors from Vite in your terminal, try running `killall node` on your command line before running `npm start` again.) 46 | 47 | #### (Optional) Configure your instance of TroveQL 48 | In the index.ts file in the /server folder, you can customize your TroveQL cache configuration: 49 | ```javascript 50 | const capacity = 5; // size limit of your cache 51 | const graphQLAPI = 'http://localhost:4000/graphql'; // your GraphQL URL endpoint 52 | const useTroveMetrics = true; // (optional) if you would like to use TroveMetrics - default is false 53 | const mutations = {}; // (optional) object where key/value pairs are mutation types/object types mutated (ex. { addMovie: 'movie', editMovie: 'movie', deleteMovie: 'movie' }) 54 | const cache = new TroveQLCache(capacity, graphQLAPI, useTroveMetrics, mutations); 55 | ``` 56 | To learn more about TroveQL's cache configruation options, visit TroveQL's GitHub page. 57 | 58 | ## Learn More 59 | Visit the TroveQL website to get more information and watch a video demo of TroveQL and TroveMetrics. 60 | 61 | Thank you so much! 62 | 63 | ## Authors 64 | Alex Klein - [GitHub](https://github.com/a-t-klein) | [LinkedIn](https://www.linkedin.com/in/alex-t-klein-183aa758/) 65 |
66 | Erika Jung - [GitHub](https://github.com/erikahjung) | [LinkedIn](https://www.linkedin.com/in/erikahjung) 67 |
68 | Sam Henderson - [GitHub](https://github.com/samhhenderson) | [LinkedIn](https://www.linkedin.com/in/samuel-h-henderson/) 69 |
70 | Tricia Yeh - [GitHub](https://github.com/triciacorwin) | [LinkedIn](https://www.linkedin.com/in/tricia-yeh/) 71 |
-------------------------------------------------------------------------------- /assets/TroveQL-black.svg: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | -------------------------------------------------------------------------------- /client/src/components/MovieDisplay.tsx: -------------------------------------------------------------------------------- 1 | import React, { useState, useEffect } from 'react'; 2 | import AddMovie from './AddMovie'; 3 | import EditModal from './EditModal'; 4 | import { Movie, GetMoviesData } from '../utils/types'; 5 | import queries from '../utils/sample-queries'; 6 | import { useNavigate } from "react-router-dom"; 7 | 8 | function MovieDisplay() { 9 | const [movies, setMovies] = useState([]); 10 | const [movieDetails, setMovieDetails] = useState([]); 11 | const [modal, setModal] = useState({display: false, movieId: null}); 12 | const navigate = useNavigate(); 13 | 14 | useEffect(() => { 15 | const query: string = queries.getMovies; 16 | fetch('/troveql', { 17 | method: 'POST', 18 | headers: { 19 | 'Content-Type': 'application/json', 20 | }, 21 | body: JSON.stringify({ 22 | query, 23 | }), 24 | }) 25 | .then((response) => { 26 | if (response.status === 200) { 27 | return response.json(); 28 | } else { 29 | return navigate('/'); 30 | } 31 | }) 32 | .then((data: GetMoviesData) => { 33 | setMovies(data.data.movies); 34 | return; 35 | }) 36 | .catch((err) => console.error('Error getting all movies: ', err)); 37 | }, []); 38 | 39 | // Get movie details 40 | function getDetails(event: React.MouseEvent) { 41 | const query: string = queries.getMovieDetails; 42 | const variables = { id: Number(event.currentTarget.id) }; 43 | fetch('/troveql', { 44 | method: 'POST', 45 | headers: { 46 | 'Content-Type': 'application/json', 47 | }, 48 | body: JSON.stringify({ 49 | query, 50 | variables, 51 | }), 52 | }) 53 | .then((response) => response.json()) 54 | .then((data) => { 55 | const detailObj = data.data.movie; 56 | const detailArr: JSX.Element[] = []; 57 | // if actor list exists, create JSX element for each actor, push it to actorList arr and reassign movie actors key with actorList arr 58 | if (detailObj.actors.length) { 59 | const actorList: JSX.Element[] = []; 60 | for (let i = 0; i < detailObj.actors.length - 1; i++) { 61 | actorList.push({detailObj.actors[i].name} | ); 62 | } 63 | actorList.push( 64 | {detailObj.actors[detailObj.actors.length - 1].name} 65 | ); 66 | detailObj.actors = actorList; 67 | } else { 68 | delete detailObj.actors; 69 | } 70 | // for every key that is not null 71 | for (const key in detailObj) { 72 | if (detailObj[key]) { 73 | detailArr.push( 74 |

75 | {key}: {detailObj[key]} 76 |

77 | ); 78 | } 79 | } 80 | setMovieDetails(detailArr); 81 | return; 82 | }) 83 | .catch((err) => console.log('Error getting movie details: ', err)); 84 | } 85 | 86 | function deleteMovie(event: React.MouseEvent) { 87 | const movieId = event.currentTarget.id; 88 | const query: string = queries.deleteMovie; 89 | const variables = { id: Number(event.currentTarget.id) }; 90 | 91 | fetch(`/troveql`, { 92 | method: 'POST', 93 | headers: { 94 | 'Content-Type': 'application/json', 95 | }, 96 | body: JSON.stringify({ 97 | query, 98 | variables, 99 | }), 100 | }) 101 | .then((response) => { 102 | if (response.ok) { 103 | const updatedMovies = movies.filter((movie) => movie.id !== movieId); 104 | setMovies(updatedMovies); 105 | setMovieDetails([]); 106 | } else { 107 | console.log('Error deleting a movie: response not OK'); 108 | } 109 | }) 110 | .catch((err) => console.log('Error deleting a movie: ', err)); 111 | } 112 | 113 | function onEdit(event: React.MouseEvent) { 114 | setModal({display: true, movieId: event.currentTarget.id}) 115 | } 116 | 117 | let movieList: any[] = []; 118 | // Display all movies 119 | movies.forEach((movie: Movie) => { 120 | movieList.push( 121 |
  • 122 |

    {movie.title}

    123 |
    124 | 127 | 130 | 133 |
    134 |
  • 135 | ); 136 | }); 137 | 138 | return ( 139 |
    140 | 141 | {modal.display && ( 142 |
    143 |
    144 | 150 |
    151 | )} 152 |
    153 |
      {movieList}
    154 |
    {movieDetails}
    155 |
    156 |
    157 | ); 158 | } 159 | 160 | export default MovieDisplay; 161 | -------------------------------------------------------------------------------- /server/data.js: -------------------------------------------------------------------------------- 1 | const Movie = require('../database/models/movieModel'); 2 | const Actor = require('../database/models/actorModel'); 3 | const ActorinMovies = require('../database/models/movie_actorModel'); 4 | 5 | // Get all movies 6 | const getMovies = async () => { 7 | try { 8 | const movies = await Movie.findAll({ 9 | attributes: ['id', 'title', 'genre', 'year'], 10 | include: [ 11 | { 12 | model: Actor, 13 | through: { 14 | model: ActorinMovies, 15 | attributes: ['id'], 16 | }, 17 | required: false, 18 | }, 19 | ], 20 | }); 21 | const allMovies = []; 22 | movies.forEach((movie) => { 23 | const actorList = []; 24 | const arrayOfActors = movie.dataValues.actors; 25 | arrayOfActors.forEach((actor) => actorList.push(actor.dataValues)); 26 | movie.dataValues.actors = actorList; 27 | // push movie.dataValues object to allMovies 28 | allMovies.push(movie.dataValues); 29 | }); 30 | return allMovies; 31 | } catch (error) { 32 | console.error('Error getting all movies with Sequelize: ', error); 33 | return; 34 | } 35 | }; 36 | 37 | // Getting a movie's details 38 | const getMovie = async (id) => { 39 | try { 40 | const movie = await Movie.findOne({ 41 | where: { 42 | id: id, 43 | }, 44 | }); 45 | return movie.dataValues; 46 | } catch (error) { 47 | console.error('Error getting movie details with Sequelize: ', error); 48 | return; 49 | } 50 | }; 51 | 52 | // get all actors for a movie 53 | const getActorsFromMovieID = async (id) => { 54 | try { 55 | const actors = await Actor.findAll({ 56 | attributes: ['id', 'name', 'gender', 'place_of_birth'], 57 | include: [ 58 | { 59 | model: Movie, 60 | through: { 61 | model: ActorinMovies, 62 | where: { 63 | movie_id: id, 64 | }, 65 | }, 66 | required: true, 67 | }, 68 | ], 69 | }); 70 | const allActors = []; 71 | actors.forEach((actor) => { 72 | // refine actor.dataValues.movies list 73 | const movieList = []; 74 | const arrayOfMovies = actor.dataValues.movies; 75 | arrayOfMovies.forEach((movie) => movieList.push(movie.dataValues)); 76 | actor.dataValues.movies = movieList; 77 | // push actor.dataValues object to allActors 78 | allActors.push(actor.dataValues); 79 | }); 80 | return allActors; 81 | } catch (error) { 82 | console.error('Error getting actors for a movie with Sequelize: ', error); 83 | return; 84 | } 85 | }; 86 | 87 | // Add a movie 88 | const addMovie = async (title) => { 89 | const addMovie = await Movie.create({ 90 | title: title, 91 | }); 92 | return addMovie.dataValues; 93 | }; 94 | 95 | // Deleting a movie from a user's movie list 96 | // Deleting movie_id row also from join table 97 | const deleteMovie = async (id) => { 98 | try { 99 | //first find the movie and await the result, then destroy 100 | //return the result of the find querey; 101 | //shape should be similar to add movie 102 | /** 103 | * id: ID! 104 | title: String! 105 | genre: String 106 | year: Int 107 | actors: [Actor] 108 | */ 109 | // Find the movie to delete 110 | const movieToDelete = await Movie.findOne({ 111 | where: { 112 | id: id, 113 | }, 114 | }); 115 | if (!movieToDelete) { 116 | console.log('Error deleting a movie: could not find movie in the database'); 117 | return; 118 | } 119 | 120 | // Delete the movie from join table first 121 | const movieInJoinTable = await ActorinMovies.destroy( 122 | { 123 | where: { 124 | movie_id: id, 125 | } 126 | }); 127 | 128 | if (movieInJoinTable === 0) { 129 | console.log('Error deleting a movie: could not find movie_actor join table for movie in the database'); 130 | } 131 | 132 | // Delete the movie from the database 133 | await Movie.destroy({ 134 | where: { 135 | id: id, 136 | }, 137 | }); 138 | return movieToDelete; 139 | } catch (error) { 140 | console.error('Error deleting a movie with Sequelize: ', error); 141 | } 142 | }; 143 | 144 | // Edit a movie 145 | const editMovie = async (id, title) => { 146 | try { 147 | // Find the movie to edit 148 | const movieToEdit = await Movie.findOne({ 149 | where: { 150 | id: id, 151 | }, 152 | }); 153 | if (!movieToEdit) { 154 | console.log('Error deleting a movie: could not find movie in the database'); 155 | return; 156 | } 157 | // Edit the movie in the database 158 | const updatedMovie = await Movie.update( 159 | {title: title }, 160 | {returning: true, where: {id: id}} 161 | ); 162 | return updatedMovie[1][0]; 163 | } catch (error) { 164 | console.error('Error deleting a movie with Sequelize: ', error); 165 | } 166 | }; 167 | 168 | 169 | // Reset movies in the db 170 | // Delete all movies 171 | // Create default movies 172 | // Add movies to join table with actors 173 | const resetMovies = async () => { 174 | try { 175 | // for new users, // if actor table is empty, 176 | // add actors to actors table, if not, do nothing 177 | // add movies to movies table, if not, do nothing 178 | // add movie and actor to join table 179 | const actorCount = await Actor.count(); 180 | const testActors = [ 181 | { name: 'Tom Hanks', gender: 'Male', place_of_birth: 'USA' }, 182 | { name: 'Leonardo DiCaprio', gender: 'Male', place_of_birth: 'USA' }, 183 | { name: 'Kate Winslet', gender: 'Female', place_of_birth: 'USA' }, 184 | { name: 'Morgan Freeman', gender: 'Male', place_of_birth: 'USA' }, 185 | { name: 'Cate Blanchett', gender: 'Male', place_of_birth: 'USA' }, 186 | { name: 'Uma Thurman', gender: 'Female', place_of_birth: 'USA' }, 187 | { name: 'Carrie-Anne Moss', gender: 'Female', place_of_birth: 'Canada' }, 188 | ]; 189 | const testMovies = [ 190 | { title: 'Pulp Fiction', genre: 'Crime', year: 1994 }, 191 | { title: 'The Godfather', genre: 'Drama', year: 1972 }, 192 | { title: 'The Dark Knight', genre: 'Action', year: 2008 }, 193 | { title: 'The Lord of the Rings', genre: 'Fantasy', year: 2003 }, 194 | { title: 'The Matrix', genre: 'Action', year: 1999 }, 195 | { title: 'Forrest Gump', genre: 'Drama', year: 1994 }, 196 | { title: 'Star Wars', genre: 'Fiction', year: 1977 }, 197 | { title: 'Titanic', genre: 'Romance', year: 1997 }, 198 | { title: 'Jurassic Park', genre: 'Adventure', year: 1993 }, 199 | ]; 200 | 201 | if (actorCount === 0) { 202 | await Actor.bulkCreate(testActors); 203 | await Movie.bulkCreate(testMovies); 204 | 205 | // add join table back in via movie title 206 | const movie1 = await Movie.findOne({ where: { title: 'Forrest Gump' } }); 207 | const movie2 = await Movie.findOne({ where: { title: 'Pulp Fiction' } }); 208 | const movie3 = await Movie.findOne({ where: { title: 'Titanic' } }); 209 | const movie4 = await Movie.findOne({ where: { title: 'Titanic' } }); 210 | const movieArr = [movie1, movie2, movie3, movie4]; 211 | 212 | const actor1 = await Actor.findOne({ where: {name: 'Morgan Freeman'} }); 213 | const actor2 = await Actor.findOne({ where: {name: 'Uma Thurman'} }); 214 | const actor3 = await Actor.findOne({ where: {name: 'Leonardo DiCaprio'} }); 215 | const actor4 = await Actor.findOne({ where: {name: 'Kate Winslet'} }); 216 | const actorArr = [actor1, actor2, actor3, actor4] 217 | 218 | const testMA = []; 219 | 220 | for (let i = 0; i < 4; i++) { 221 | testMA.push({ 222 | movie_id: movieArr[i].dataValues.id, 223 | actor_id: actorArr[i].dataValues.id 224 | }) 225 | } 226 | 227 | await ActorinMovies.bulkCreate(testMA); 228 | 229 | } else if (actorCount !== 0) { 230 | await ActorinMovies.destroy({ where: {} }); 231 | await Movie.destroy({ where: {} }); 232 | await Movie.bulkCreate(testMovies); 233 | // add join table back in via movie title 234 | const movie1 = await Movie.findOne({ where: { title: 'Forrest Gump' } }); 235 | const movie2 = await Movie.findOne({ where: { title: 'Pulp Fiction' } }); 236 | const movie3 = await Movie.findOne({ where: { title: 'Titanic' } }); 237 | const movie4 = await Movie.findOne({ where: { title: 'Titanic' } }); 238 | const movieArr = [movie1, movie2, movie3, movie4]; 239 | 240 | const actor1 = await Actor.findOne({ where: {name: 'Morgan Freeman'} }); 241 | const actor2 = await Actor.findOne({ where: {name: 'Uma Thurman'} }); 242 | const actor3 = await Actor.findOne({ where: {name: 'Leonardo DiCaprio'} }); 243 | const actor4 = await Actor.findOne({ where: {name: 'Kate Winslet'} }); 244 | const actorArr = [actor1, actor2, actor3, actor4] 245 | 246 | const testMA = []; 247 | 248 | for (let i = 0; i < 4; i++) { 249 | testMA.push({ 250 | movie_id: movieArr[i].dataValues.id, 251 | actor_id: actorArr[i].dataValues.id 252 | }) 253 | } 254 | 255 | await ActorinMovies.bulkCreate(testMA); 256 | return; 257 | } 258 | } catch (error) { 259 | console.error('Error resetting movies in the database with Sequelize: ', error); 260 | } 261 | }; 262 | 263 | module.exports = { 264 | getMovies, 265 | getMovie, 266 | getActorsFromMovieID, 267 | addMovie, 268 | deleteMovie, 269 | editMovie, 270 | resetMovies, 271 | }; 272 | -------------------------------------------------------------------------------- /server/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "server", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "@graphql-tools/schema": "^9.0.17", 13 | "cors": "^2.8.5", 14 | "dotenv": "^16.0.3", 15 | "dotenv-cli": "^7.2.1", 16 | "express": "^4.18.2", 17 | "express-graphql": "^0.12.0", 18 | "troveql": "^0.1.7" 19 | }, 20 | "devDependencies": { 21 | "@types/express": "^4.17.17", 22 | "nodemon": "^2.0.21", 23 | "sequelize": "^6.31.0", 24 | "tsc-watch": "^6.0.0", 25 | "typescript": "^5.0.2" 26 | } 27 | }, 28 | "node_modules/@graphql-tools/merge": { 29 | "version": "8.4.0", 30 | "resolved": "https://registry.npmjs.org/@graphql-tools/merge/-/merge-8.4.0.tgz", 31 | "integrity": "sha512-3XYCWe0d3I4F1azNj1CdShlbHfTIfiDgj00R9uvFH8tHKh7i1IWN3F7QQYovcHKhayaR6zPok3YYMESYQcBoaA==", 32 | "dependencies": { 33 | "@graphql-tools/utils": "9.2.1", 34 | "tslib": "^2.4.0" 35 | }, 36 | "peerDependencies": { 37 | "graphql": "^14.0.0 || ^15.0.0 || ^16.0.0 || ^17.0.0" 38 | } 39 | }, 40 | "node_modules/@graphql-tools/schema": { 41 | "version": "9.0.17", 42 | "resolved": "https://registry.npmjs.org/@graphql-tools/schema/-/schema-9.0.17.tgz", 43 | "integrity": "sha512-HVLq0ecbkuXhJlpZ50IHP5nlISqH2GbNgjBJhhRzHeXhfwlUOT4ISXGquWTmuq61K0xSaO0aCjMpxe4QYbKTng==", 44 | "dependencies": { 45 | "@graphql-tools/merge": "8.4.0", 46 | "@graphql-tools/utils": "9.2.1", 47 | "tslib": "^2.4.0", 48 | "value-or-promise": "1.0.12" 49 | }, 50 | "peerDependencies": { 51 | "graphql": "^14.0.0 || ^15.0.0 || ^16.0.0 || ^17.0.0" 52 | } 53 | }, 54 | "node_modules/@graphql-tools/utils": { 55 | "version": "9.2.1", 56 | "resolved": "https://registry.npmjs.org/@graphql-tools/utils/-/utils-9.2.1.tgz", 57 | "integrity": "sha512-WUw506Ql6xzmOORlriNrD6Ugx+HjVgYxt9KCXD9mHAak+eaXSwuGGPyE60hy9xaDEoXKBsG7SkG69ybitaVl6A==", 58 | "dependencies": { 59 | "@graphql-typed-document-node/core": "^3.1.1", 60 | "tslib": "^2.4.0" 61 | }, 62 | "peerDependencies": { 63 | "graphql": "^14.0.0 || ^15.0.0 || ^16.0.0 || ^17.0.0" 64 | } 65 | }, 66 | "node_modules/@graphql-typed-document-node/core": { 67 | "version": "3.2.0", 68 | "resolved": "https://registry.npmjs.org/@graphql-typed-document-node/core/-/core-3.2.0.tgz", 69 | "integrity": "sha512-mB9oAsNCm9aM3/SOv4YtBMqZbYj10R7dkq8byBqxGY/ncFwhf2oQzMV+LCRlWoDSEBJ3COiR1yeDvMtsoOsuFQ==", 70 | "peerDependencies": { 71 | "graphql": "^0.8.0 || ^0.9.0 || ^0.10.0 || ^0.11.0 || ^0.12.0 || ^0.13.0 || ^14.0.0 || ^15.0.0 || ^16.0.0 || ^17.0.0" 72 | } 73 | }, 74 | "node_modules/@types/body-parser": { 75 | "version": "1.19.2", 76 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 77 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 78 | "dev": true, 79 | "dependencies": { 80 | "@types/connect": "*", 81 | "@types/node": "*" 82 | } 83 | }, 84 | "node_modules/@types/connect": { 85 | "version": "3.4.35", 86 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 87 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 88 | "dev": true, 89 | "dependencies": { 90 | "@types/node": "*" 91 | } 92 | }, 93 | "node_modules/@types/debug": { 94 | "version": "4.1.7", 95 | "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.7.tgz", 96 | "integrity": "sha512-9AonUzyTjXXhEOa0DnqpzZi6VHlqKMswga9EXjpXnnqxwLtdvPPtlO8evrI5D9S6asFRCQ6v+wpiUKbw+vKqyg==", 97 | "dev": true, 98 | "dependencies": { 99 | "@types/ms": "*" 100 | } 101 | }, 102 | "node_modules/@types/express": { 103 | "version": "4.17.17", 104 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.17.tgz", 105 | "integrity": "sha512-Q4FmmuLGBG58btUnfS1c1r/NQdlp3DMfGDGig8WhfpA2YRUtEkxAjkZb0yvplJGYdF1fsQ81iMDcH24sSCNC/Q==", 106 | "dev": true, 107 | "dependencies": { 108 | "@types/body-parser": "*", 109 | "@types/express-serve-static-core": "^4.17.33", 110 | "@types/qs": "*", 111 | "@types/serve-static": "*" 112 | } 113 | }, 114 | "node_modules/@types/express-serve-static-core": { 115 | "version": "4.17.33", 116 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.33.tgz", 117 | "integrity": "sha512-TPBqmR/HRYI3eC2E5hmiivIzv+bidAfXofM+sbonAGvyDhySGw9/PQZFt2BLOrjUUR++4eJVpx6KnLQK1Fk9tA==", 118 | "dev": true, 119 | "dependencies": { 120 | "@types/node": "*", 121 | "@types/qs": "*", 122 | "@types/range-parser": "*" 123 | } 124 | }, 125 | "node_modules/@types/mime": { 126 | "version": "3.0.1", 127 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz", 128 | "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==", 129 | "dev": true 130 | }, 131 | "node_modules/@types/ms": { 132 | "version": "0.7.31", 133 | "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", 134 | "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==", 135 | "dev": true 136 | }, 137 | "node_modules/@types/node": { 138 | "version": "18.15.9", 139 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.15.9.tgz", 140 | "integrity": "sha512-dUxhiNzBLr6IqlZXz6e/rN2YQXlFgOei/Dxy+e3cyXTJ4txSUbGT2/fmnD6zd/75jDMeW5bDee+YXxlFKHoV0A==", 141 | "dev": true 142 | }, 143 | "node_modules/@types/qs": { 144 | "version": "6.9.7", 145 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 146 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 147 | "dev": true 148 | }, 149 | "node_modules/@types/range-parser": { 150 | "version": "1.2.4", 151 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 152 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 153 | "dev": true 154 | }, 155 | "node_modules/@types/serve-static": { 156 | "version": "1.15.1", 157 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.1.tgz", 158 | "integrity": "sha512-NUo5XNiAdULrJENtJXZZ3fHtfMolzZwczzBbnAeBbqBwG+LaG6YaJtuwzwGSQZ2wsCrxjEhNNjAkKigy3n8teQ==", 159 | "dev": true, 160 | "dependencies": { 161 | "@types/mime": "*", 162 | "@types/node": "*" 163 | } 164 | }, 165 | "node_modules/@types/validator": { 166 | "version": "13.7.14", 167 | "resolved": "https://registry.npmjs.org/@types/validator/-/validator-13.7.14.tgz", 168 | "integrity": "sha512-J6OAed6rhN6zyqL9Of6ZMamhlsOEU/poBVvbHr/dKOYKTeuYYMlDkMv+b6UUV0o2i0tw73cgyv/97WTWaUl0/g==", 169 | "dev": true 170 | }, 171 | "node_modules/abbrev": { 172 | "version": "1.1.1", 173 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 174 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 175 | "dev": true 176 | }, 177 | "node_modules/accepts": { 178 | "version": "1.3.8", 179 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 180 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 181 | "dependencies": { 182 | "mime-types": "~2.1.34", 183 | "negotiator": "0.6.3" 184 | }, 185 | "engines": { 186 | "node": ">= 0.6" 187 | } 188 | }, 189 | "node_modules/anymatch": { 190 | "version": "3.1.3", 191 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 192 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 193 | "dev": true, 194 | "dependencies": { 195 | "normalize-path": "^3.0.0", 196 | "picomatch": "^2.0.4" 197 | }, 198 | "engines": { 199 | "node": ">= 8" 200 | } 201 | }, 202 | "node_modules/array-flatten": { 203 | "version": "1.1.1", 204 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 205 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 206 | }, 207 | "node_modules/balanced-match": { 208 | "version": "1.0.2", 209 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 210 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 211 | "dev": true 212 | }, 213 | "node_modules/binary-extensions": { 214 | "version": "2.2.0", 215 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 216 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 217 | "dev": true, 218 | "engines": { 219 | "node": ">=8" 220 | } 221 | }, 222 | "node_modules/body-parser": { 223 | "version": "1.20.1", 224 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 225 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 226 | "dependencies": { 227 | "bytes": "3.1.2", 228 | "content-type": "~1.0.4", 229 | "debug": "2.6.9", 230 | "depd": "2.0.0", 231 | "destroy": "1.2.0", 232 | "http-errors": "2.0.0", 233 | "iconv-lite": "0.4.24", 234 | "on-finished": "2.4.1", 235 | "qs": "6.11.0", 236 | "raw-body": "2.5.1", 237 | "type-is": "~1.6.18", 238 | "unpipe": "1.0.0" 239 | }, 240 | "engines": { 241 | "node": ">= 0.8", 242 | "npm": "1.2.8000 || >= 1.4.16" 243 | } 244 | }, 245 | "node_modules/brace-expansion": { 246 | "version": "1.1.11", 247 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 248 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 249 | "dev": true, 250 | "dependencies": { 251 | "balanced-match": "^1.0.0", 252 | "concat-map": "0.0.1" 253 | } 254 | }, 255 | "node_modules/braces": { 256 | "version": "3.0.2", 257 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 258 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 259 | "dev": true, 260 | "dependencies": { 261 | "fill-range": "^7.0.1" 262 | }, 263 | "engines": { 264 | "node": ">=8" 265 | } 266 | }, 267 | "node_modules/bytes": { 268 | "version": "3.1.2", 269 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 270 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 271 | "engines": { 272 | "node": ">= 0.8" 273 | } 274 | }, 275 | "node_modules/call-bind": { 276 | "version": "1.0.2", 277 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 278 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 279 | "dependencies": { 280 | "function-bind": "^1.1.1", 281 | "get-intrinsic": "^1.0.2" 282 | }, 283 | "funding": { 284 | "url": "https://github.com/sponsors/ljharb" 285 | } 286 | }, 287 | "node_modules/chokidar": { 288 | "version": "3.5.3", 289 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 290 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 291 | "dev": true, 292 | "funding": [ 293 | { 294 | "type": "individual", 295 | "url": "https://paulmillr.com/funding/" 296 | } 297 | ], 298 | "dependencies": { 299 | "anymatch": "~3.1.2", 300 | "braces": "~3.0.2", 301 | "glob-parent": "~5.1.2", 302 | "is-binary-path": "~2.1.0", 303 | "is-glob": "~4.0.1", 304 | "normalize-path": "~3.0.0", 305 | "readdirp": "~3.6.0" 306 | }, 307 | "engines": { 308 | "node": ">= 8.10.0" 309 | }, 310 | "optionalDependencies": { 311 | "fsevents": "~2.3.2" 312 | } 313 | }, 314 | "node_modules/concat-map": { 315 | "version": "0.0.1", 316 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 317 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 318 | "dev": true 319 | }, 320 | "node_modules/content-disposition": { 321 | "version": "0.5.4", 322 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 323 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 324 | "dependencies": { 325 | "safe-buffer": "5.2.1" 326 | }, 327 | "engines": { 328 | "node": ">= 0.6" 329 | } 330 | }, 331 | "node_modules/content-type": { 332 | "version": "1.0.5", 333 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 334 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 335 | "engines": { 336 | "node": ">= 0.6" 337 | } 338 | }, 339 | "node_modules/cookie": { 340 | "version": "0.5.0", 341 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 342 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 343 | "engines": { 344 | "node": ">= 0.6" 345 | } 346 | }, 347 | "node_modules/cookie-signature": { 348 | "version": "1.0.6", 349 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 350 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 351 | }, 352 | "node_modules/cors": { 353 | "version": "2.8.5", 354 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 355 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 356 | "dependencies": { 357 | "object-assign": "^4", 358 | "vary": "^1" 359 | }, 360 | "engines": { 361 | "node": ">= 0.10" 362 | } 363 | }, 364 | "node_modules/cross-spawn": { 365 | "version": "7.0.3", 366 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 367 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 368 | "dependencies": { 369 | "path-key": "^3.1.0", 370 | "shebang-command": "^2.0.0", 371 | "which": "^2.0.1" 372 | }, 373 | "engines": { 374 | "node": ">= 8" 375 | } 376 | }, 377 | "node_modules/debug": { 378 | "version": "2.6.9", 379 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 380 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 381 | "dependencies": { 382 | "ms": "2.0.0" 383 | } 384 | }, 385 | "node_modules/depd": { 386 | "version": "2.0.0", 387 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 388 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 389 | "engines": { 390 | "node": ">= 0.8" 391 | } 392 | }, 393 | "node_modules/destroy": { 394 | "version": "1.2.0", 395 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 396 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 397 | "engines": { 398 | "node": ">= 0.8", 399 | "npm": "1.2.8000 || >= 1.4.16" 400 | } 401 | }, 402 | "node_modules/dotenv": { 403 | "version": "16.0.3", 404 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 405 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==", 406 | "engines": { 407 | "node": ">=12" 408 | } 409 | }, 410 | "node_modules/dotenv-cli": { 411 | "version": "7.2.1", 412 | "resolved": "https://registry.npmjs.org/dotenv-cli/-/dotenv-cli-7.2.1.tgz", 413 | "integrity": "sha512-ODHbGTskqRtXAzZapDPvgNuDVQApu4oKX8lZW7Y0+9hKA6le1ZJlyRS687oU9FXjOVEDU/VFV6zI125HzhM1UQ==", 414 | "dependencies": { 415 | "cross-spawn": "^7.0.3", 416 | "dotenv": "^16.0.0", 417 | "dotenv-expand": "^10.0.0", 418 | "minimist": "^1.2.6" 419 | }, 420 | "bin": { 421 | "dotenv": "cli.js" 422 | } 423 | }, 424 | "node_modules/dotenv-expand": { 425 | "version": "10.0.0", 426 | "resolved": "https://registry.npmjs.org/dotenv-expand/-/dotenv-expand-10.0.0.tgz", 427 | "integrity": "sha512-GopVGCpVS1UKH75VKHGuQFqS1Gusej0z4FyQkPdwjil2gNIv+LNsqBlboOzpJFZKVT95GkCyWJbBSdFEFUWI2A==", 428 | "engines": { 429 | "node": ">=12" 430 | } 431 | }, 432 | "node_modules/dottie": { 433 | "version": "2.0.3", 434 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.3.tgz", 435 | "integrity": "sha512-4liA0PuRkZWQFQjwBypdxPfZaRWiv5tkhMXY2hzsa2pNf5s7U3m9cwUchfNKe8wZQxdGPQQzO6Rm2uGe0rvohQ==", 436 | "dev": true 437 | }, 438 | "node_modules/duplexer": { 439 | "version": "0.1.2", 440 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", 441 | "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==", 442 | "dev": true 443 | }, 444 | "node_modules/ee-first": { 445 | "version": "1.1.1", 446 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 447 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 448 | }, 449 | "node_modules/encodeurl": { 450 | "version": "1.0.2", 451 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 452 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 453 | "engines": { 454 | "node": ">= 0.8" 455 | } 456 | }, 457 | "node_modules/escape-html": { 458 | "version": "1.0.3", 459 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 460 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 461 | }, 462 | "node_modules/etag": { 463 | "version": "1.8.1", 464 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 465 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 466 | "engines": { 467 | "node": ">= 0.6" 468 | } 469 | }, 470 | "node_modules/event-stream": { 471 | "version": "3.3.4", 472 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 473 | "integrity": "sha512-QHpkERcGsR0T7Qm3HNJSyXKEEj8AHNxkY3PK8TS2KJvQ7NiSHe3DDpwVKKtoYprL/AreyzFBeIkBIWChAqn60g==", 474 | "dev": true, 475 | "dependencies": { 476 | "duplexer": "~0.1.1", 477 | "from": "~0", 478 | "map-stream": "~0.1.0", 479 | "pause-stream": "0.0.11", 480 | "split": "0.3", 481 | "stream-combiner": "~0.0.4", 482 | "through": "~2.3.1" 483 | } 484 | }, 485 | "node_modules/express": { 486 | "version": "4.18.2", 487 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 488 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 489 | "dependencies": { 490 | "accepts": "~1.3.8", 491 | "array-flatten": "1.1.1", 492 | "body-parser": "1.20.1", 493 | "content-disposition": "0.5.4", 494 | "content-type": "~1.0.4", 495 | "cookie": "0.5.0", 496 | "cookie-signature": "1.0.6", 497 | "debug": "2.6.9", 498 | "depd": "2.0.0", 499 | "encodeurl": "~1.0.2", 500 | "escape-html": "~1.0.3", 501 | "etag": "~1.8.1", 502 | "finalhandler": "1.2.0", 503 | "fresh": "0.5.2", 504 | "http-errors": "2.0.0", 505 | "merge-descriptors": "1.0.1", 506 | "methods": "~1.1.2", 507 | "on-finished": "2.4.1", 508 | "parseurl": "~1.3.3", 509 | "path-to-regexp": "0.1.7", 510 | "proxy-addr": "~2.0.7", 511 | "qs": "6.11.0", 512 | "range-parser": "~1.2.1", 513 | "safe-buffer": "5.2.1", 514 | "send": "0.18.0", 515 | "serve-static": "1.15.0", 516 | "setprototypeof": "1.2.0", 517 | "statuses": "2.0.1", 518 | "type-is": "~1.6.18", 519 | "utils-merge": "1.0.1", 520 | "vary": "~1.1.2" 521 | }, 522 | "engines": { 523 | "node": ">= 0.10.0" 524 | } 525 | }, 526 | "node_modules/express-graphql": { 527 | "version": "0.12.0", 528 | "resolved": "https://registry.npmjs.org/express-graphql/-/express-graphql-0.12.0.tgz", 529 | "integrity": "sha512-DwYaJQy0amdy3pgNtiTDuGGM2BLdj+YO2SgbKoLliCfuHv3VVTt7vNG/ZqK2hRYjtYHE2t2KB705EU94mE64zg==", 530 | "deprecated": "This package is no longer maintained. We recommend using `graphql-http` instead. Please consult the migration document https://github.com/graphql/graphql-http#migrating-express-grpahql.", 531 | "dependencies": { 532 | "accepts": "^1.3.7", 533 | "content-type": "^1.0.4", 534 | "http-errors": "1.8.0", 535 | "raw-body": "^2.4.1" 536 | }, 537 | "engines": { 538 | "node": ">= 10.x" 539 | }, 540 | "peerDependencies": { 541 | "graphql": "^14.7.0 || ^15.3.0" 542 | } 543 | }, 544 | "node_modules/express-graphql/node_modules/depd": { 545 | "version": "1.1.2", 546 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 547 | "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", 548 | "engines": { 549 | "node": ">= 0.6" 550 | } 551 | }, 552 | "node_modules/express-graphql/node_modules/http-errors": { 553 | "version": "1.8.0", 554 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.0.tgz", 555 | "integrity": "sha512-4I8r0C5JDhT5VkvI47QktDW75rNlGVsUf/8hzjCC/wkWI/jdTRmBb9aI7erSG82r1bjKY3F6k28WnsVxB1C73A==", 556 | "dependencies": { 557 | "depd": "~1.1.2", 558 | "inherits": "2.0.4", 559 | "setprototypeof": "1.2.0", 560 | "statuses": ">= 1.5.0 < 2", 561 | "toidentifier": "1.0.0" 562 | }, 563 | "engines": { 564 | "node": ">= 0.6" 565 | } 566 | }, 567 | "node_modules/express-graphql/node_modules/statuses": { 568 | "version": "1.5.0", 569 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 570 | "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", 571 | "engines": { 572 | "node": ">= 0.6" 573 | } 574 | }, 575 | "node_modules/express-graphql/node_modules/toidentifier": { 576 | "version": "1.0.0", 577 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 578 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 579 | "engines": { 580 | "node": ">=0.6" 581 | } 582 | }, 583 | "node_modules/fill-range": { 584 | "version": "7.0.1", 585 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 586 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 587 | "dev": true, 588 | "dependencies": { 589 | "to-regex-range": "^5.0.1" 590 | }, 591 | "engines": { 592 | "node": ">=8" 593 | } 594 | }, 595 | "node_modules/finalhandler": { 596 | "version": "1.2.0", 597 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 598 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 599 | "dependencies": { 600 | "debug": "2.6.9", 601 | "encodeurl": "~1.0.2", 602 | "escape-html": "~1.0.3", 603 | "on-finished": "2.4.1", 604 | "parseurl": "~1.3.3", 605 | "statuses": "2.0.1", 606 | "unpipe": "~1.0.0" 607 | }, 608 | "engines": { 609 | "node": ">= 0.8" 610 | } 611 | }, 612 | "node_modules/forwarded": { 613 | "version": "0.2.0", 614 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 615 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 616 | "engines": { 617 | "node": ">= 0.6" 618 | } 619 | }, 620 | "node_modules/fresh": { 621 | "version": "0.5.2", 622 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 623 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 624 | "engines": { 625 | "node": ">= 0.6" 626 | } 627 | }, 628 | "node_modules/from": { 629 | "version": "0.1.7", 630 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 631 | "integrity": "sha512-twe20eF1OxVxp/ML/kq2p1uc6KvFK/+vs8WjEbeKmV2He22MKm7YF2ANIt+EOqhJ5L3K/SuuPhk0hWQDjOM23g==", 632 | "dev": true 633 | }, 634 | "node_modules/fsevents": { 635 | "version": "2.3.2", 636 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 637 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 638 | "dev": true, 639 | "hasInstallScript": true, 640 | "optional": true, 641 | "os": [ 642 | "darwin" 643 | ], 644 | "engines": { 645 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 646 | } 647 | }, 648 | "node_modules/function-bind": { 649 | "version": "1.1.1", 650 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 651 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 652 | }, 653 | "node_modules/get-intrinsic": { 654 | "version": "1.2.0", 655 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.0.tgz", 656 | "integrity": "sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==", 657 | "dependencies": { 658 | "function-bind": "^1.1.1", 659 | "has": "^1.0.3", 660 | "has-symbols": "^1.0.3" 661 | }, 662 | "funding": { 663 | "url": "https://github.com/sponsors/ljharb" 664 | } 665 | }, 666 | "node_modules/glob-parent": { 667 | "version": "5.1.2", 668 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 669 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 670 | "dev": true, 671 | "dependencies": { 672 | "is-glob": "^4.0.1" 673 | }, 674 | "engines": { 675 | "node": ">= 6" 676 | } 677 | }, 678 | "node_modules/graphql": { 679 | "version": "15.8.0", 680 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-15.8.0.tgz", 681 | "integrity": "sha512-5gghUc24tP9HRznNpV2+FIoq3xKkj5dTQqf4v0CpdPbFVwFkWoxOM+o+2OC9ZSvjEMTjfmG9QT+gcvggTwW1zw==", 682 | "peer": true, 683 | "engines": { 684 | "node": ">= 10.x" 685 | } 686 | }, 687 | "node_modules/has": { 688 | "version": "1.0.3", 689 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 690 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 691 | "dependencies": { 692 | "function-bind": "^1.1.1" 693 | }, 694 | "engines": { 695 | "node": ">= 0.4.0" 696 | } 697 | }, 698 | "node_modules/has-flag": { 699 | "version": "3.0.0", 700 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 701 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 702 | "dev": true, 703 | "engines": { 704 | "node": ">=4" 705 | } 706 | }, 707 | "node_modules/has-symbols": { 708 | "version": "1.0.3", 709 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 710 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 711 | "engines": { 712 | "node": ">= 0.4" 713 | }, 714 | "funding": { 715 | "url": "https://github.com/sponsors/ljharb" 716 | } 717 | }, 718 | "node_modules/http-errors": { 719 | "version": "2.0.0", 720 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 721 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 722 | "dependencies": { 723 | "depd": "2.0.0", 724 | "inherits": "2.0.4", 725 | "setprototypeof": "1.2.0", 726 | "statuses": "2.0.1", 727 | "toidentifier": "1.0.1" 728 | }, 729 | "engines": { 730 | "node": ">= 0.8" 731 | } 732 | }, 733 | "node_modules/iconv-lite": { 734 | "version": "0.4.24", 735 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 736 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 737 | "dependencies": { 738 | "safer-buffer": ">= 2.1.2 < 3" 739 | }, 740 | "engines": { 741 | "node": ">=0.10.0" 742 | } 743 | }, 744 | "node_modules/ignore-by-default": { 745 | "version": "1.0.1", 746 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 747 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", 748 | "dev": true 749 | }, 750 | "node_modules/inflection": { 751 | "version": "1.13.4", 752 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.4.tgz", 753 | "integrity": "sha512-6I/HUDeYFfuNCVS3td055BaXBwKYuzw7K3ExVMStBowKo9oOAMJIXIHvdyR3iboTCp1b+1i5DSkIZTcwIktuDw==", 754 | "dev": true, 755 | "engines": [ 756 | "node >= 0.4.0" 757 | ] 758 | }, 759 | "node_modules/inherits": { 760 | "version": "2.0.4", 761 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 762 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 763 | }, 764 | "node_modules/ipaddr.js": { 765 | "version": "1.9.1", 766 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 767 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 768 | "engines": { 769 | "node": ">= 0.10" 770 | } 771 | }, 772 | "node_modules/is-binary-path": { 773 | "version": "2.1.0", 774 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 775 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 776 | "dev": true, 777 | "dependencies": { 778 | "binary-extensions": "^2.0.0" 779 | }, 780 | "engines": { 781 | "node": ">=8" 782 | } 783 | }, 784 | "node_modules/is-extglob": { 785 | "version": "2.1.1", 786 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 787 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 788 | "dev": true, 789 | "engines": { 790 | "node": ">=0.10.0" 791 | } 792 | }, 793 | "node_modules/is-glob": { 794 | "version": "4.0.3", 795 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 796 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 797 | "dev": true, 798 | "dependencies": { 799 | "is-extglob": "^2.1.1" 800 | }, 801 | "engines": { 802 | "node": ">=0.10.0" 803 | } 804 | }, 805 | "node_modules/is-number": { 806 | "version": "7.0.0", 807 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 808 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 809 | "dev": true, 810 | "engines": { 811 | "node": ">=0.12.0" 812 | } 813 | }, 814 | "node_modules/isexe": { 815 | "version": "2.0.0", 816 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 817 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" 818 | }, 819 | "node_modules/lodash": { 820 | "version": "4.17.21", 821 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 822 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 823 | "dev": true 824 | }, 825 | "node_modules/lru-cache": { 826 | "version": "6.0.0", 827 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 828 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 829 | "dev": true, 830 | "dependencies": { 831 | "yallist": "^4.0.0" 832 | }, 833 | "engines": { 834 | "node": ">=10" 835 | } 836 | }, 837 | "node_modules/map-stream": { 838 | "version": "0.1.0", 839 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 840 | "integrity": "sha512-CkYQrPYZfWnu/DAmVCpTSX/xHpKZ80eKh2lAkyA6AJTef6bW+6JpbQZN5rofum7da+SyN1bi5ctTm+lTfcCW3g==", 841 | "dev": true 842 | }, 843 | "node_modules/media-typer": { 844 | "version": "0.3.0", 845 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 846 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 847 | "engines": { 848 | "node": ">= 0.6" 849 | } 850 | }, 851 | "node_modules/merge-descriptors": { 852 | "version": "1.0.1", 853 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 854 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 855 | }, 856 | "node_modules/methods": { 857 | "version": "1.1.2", 858 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 859 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 860 | "engines": { 861 | "node": ">= 0.6" 862 | } 863 | }, 864 | "node_modules/mime": { 865 | "version": "1.6.0", 866 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 867 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 868 | "bin": { 869 | "mime": "cli.js" 870 | }, 871 | "engines": { 872 | "node": ">=4" 873 | } 874 | }, 875 | "node_modules/mime-db": { 876 | "version": "1.52.0", 877 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 878 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 879 | "engines": { 880 | "node": ">= 0.6" 881 | } 882 | }, 883 | "node_modules/mime-types": { 884 | "version": "2.1.35", 885 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 886 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 887 | "dependencies": { 888 | "mime-db": "1.52.0" 889 | }, 890 | "engines": { 891 | "node": ">= 0.6" 892 | } 893 | }, 894 | "node_modules/minimatch": { 895 | "version": "3.1.2", 896 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 897 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 898 | "dev": true, 899 | "dependencies": { 900 | "brace-expansion": "^1.1.7" 901 | }, 902 | "engines": { 903 | "node": "*" 904 | } 905 | }, 906 | "node_modules/minimist": { 907 | "version": "1.2.8", 908 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 909 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 910 | "funding": { 911 | "url": "https://github.com/sponsors/ljharb" 912 | } 913 | }, 914 | "node_modules/moment": { 915 | "version": "2.29.4", 916 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 917 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 918 | "dev": true, 919 | "engines": { 920 | "node": "*" 921 | } 922 | }, 923 | "node_modules/moment-timezone": { 924 | "version": "0.5.43", 925 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.43.tgz", 926 | "integrity": "sha512-72j3aNyuIsDxdF1i7CEgV2FfxM1r6aaqJyLB2vwb33mXYyoyLly+F1zbWqhA3/bVIoJ4szlUoMbUnVdid32NUQ==", 927 | "dev": true, 928 | "dependencies": { 929 | "moment": "^2.29.4" 930 | }, 931 | "engines": { 932 | "node": "*" 933 | } 934 | }, 935 | "node_modules/ms": { 936 | "version": "2.0.0", 937 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 938 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 939 | }, 940 | "node_modules/negotiator": { 941 | "version": "0.6.3", 942 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 943 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 944 | "engines": { 945 | "node": ">= 0.6" 946 | } 947 | }, 948 | "node_modules/node-cleanup": { 949 | "version": "2.1.2", 950 | "resolved": "https://registry.npmjs.org/node-cleanup/-/node-cleanup-2.1.2.tgz", 951 | "integrity": "sha512-qN8v/s2PAJwGUtr1/hYTpNKlD6Y9rc4p8KSmJXyGdYGZsDGKXrGThikLFP9OCHFeLeEpQzPwiAtdIvBLqm//Hw==", 952 | "dev": true 953 | }, 954 | "node_modules/nodemon": { 955 | "version": "2.0.21", 956 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.21.tgz", 957 | "integrity": "sha512-djN/n2549DUtY33S7o1djRCd7dEm0kBnj9c7S9XVXqRUbuggN1MZH/Nqa+5RFQr63Fbefq37nFXAE9VU86yL1A==", 958 | "dev": true, 959 | "dependencies": { 960 | "chokidar": "^3.5.2", 961 | "debug": "^3.2.7", 962 | "ignore-by-default": "^1.0.1", 963 | "minimatch": "^3.1.2", 964 | "pstree.remy": "^1.1.8", 965 | "semver": "^5.7.1", 966 | "simple-update-notifier": "^1.0.7", 967 | "supports-color": "^5.5.0", 968 | "touch": "^3.1.0", 969 | "undefsafe": "^2.0.5" 970 | }, 971 | "bin": { 972 | "nodemon": "bin/nodemon.js" 973 | }, 974 | "engines": { 975 | "node": ">=8.10.0" 976 | }, 977 | "funding": { 978 | "type": "opencollective", 979 | "url": "https://opencollective.com/nodemon" 980 | } 981 | }, 982 | "node_modules/nodemon/node_modules/debug": { 983 | "version": "3.2.7", 984 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 985 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 986 | "dev": true, 987 | "dependencies": { 988 | "ms": "^2.1.1" 989 | } 990 | }, 991 | "node_modules/nodemon/node_modules/ms": { 992 | "version": "2.1.3", 993 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 994 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 995 | "dev": true 996 | }, 997 | "node_modules/nopt": { 998 | "version": "1.0.10", 999 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1000 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 1001 | "dev": true, 1002 | "dependencies": { 1003 | "abbrev": "1" 1004 | }, 1005 | "bin": { 1006 | "nopt": "bin/nopt.js" 1007 | }, 1008 | "engines": { 1009 | "node": "*" 1010 | } 1011 | }, 1012 | "node_modules/normalize-path": { 1013 | "version": "3.0.0", 1014 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1015 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1016 | "dev": true, 1017 | "engines": { 1018 | "node": ">=0.10.0" 1019 | } 1020 | }, 1021 | "node_modules/object-assign": { 1022 | "version": "4.1.1", 1023 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1024 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1025 | "engines": { 1026 | "node": ">=0.10.0" 1027 | } 1028 | }, 1029 | "node_modules/object-inspect": { 1030 | "version": "1.12.3", 1031 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 1032 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 1033 | "funding": { 1034 | "url": "https://github.com/sponsors/ljharb" 1035 | } 1036 | }, 1037 | "node_modules/on-finished": { 1038 | "version": "2.4.1", 1039 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1040 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1041 | "dependencies": { 1042 | "ee-first": "1.1.1" 1043 | }, 1044 | "engines": { 1045 | "node": ">= 0.8" 1046 | } 1047 | }, 1048 | "node_modules/parseurl": { 1049 | "version": "1.3.3", 1050 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1051 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1052 | "engines": { 1053 | "node": ">= 0.8" 1054 | } 1055 | }, 1056 | "node_modules/path-key": { 1057 | "version": "3.1.1", 1058 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1059 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1060 | "engines": { 1061 | "node": ">=8" 1062 | } 1063 | }, 1064 | "node_modules/path-to-regexp": { 1065 | "version": "0.1.7", 1066 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1067 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 1068 | }, 1069 | "node_modules/pause-stream": { 1070 | "version": "0.0.11", 1071 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1072 | "integrity": "sha512-e3FBlXLmN/D1S+zHzanP4E/4Z60oFAa3O051qt1pxa7DEJWKAyil6upYVXCWadEnuoqa4Pkc9oUx9zsxYeRv8A==", 1073 | "dev": true, 1074 | "dependencies": { 1075 | "through": "~2.3" 1076 | } 1077 | }, 1078 | "node_modules/pg-connection-string": { 1079 | "version": "2.5.0", 1080 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.5.0.tgz", 1081 | "integrity": "sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ==", 1082 | "dev": true 1083 | }, 1084 | "node_modules/picomatch": { 1085 | "version": "2.3.1", 1086 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1087 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1088 | "dev": true, 1089 | "engines": { 1090 | "node": ">=8.6" 1091 | }, 1092 | "funding": { 1093 | "url": "https://github.com/sponsors/jonschlinkert" 1094 | } 1095 | }, 1096 | "node_modules/proxy-addr": { 1097 | "version": "2.0.7", 1098 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1099 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1100 | "dependencies": { 1101 | "forwarded": "0.2.0", 1102 | "ipaddr.js": "1.9.1" 1103 | }, 1104 | "engines": { 1105 | "node": ">= 0.10" 1106 | } 1107 | }, 1108 | "node_modules/ps-tree": { 1109 | "version": "1.2.0", 1110 | "resolved": "https://registry.npmjs.org/ps-tree/-/ps-tree-1.2.0.tgz", 1111 | "integrity": "sha512-0VnamPPYHl4uaU/nSFeZZpR21QAWRz+sRv4iW9+v/GS/J5U5iZB5BNN6J0RMoOvdx2gWM2+ZFMIm58q24e4UYA==", 1112 | "dev": true, 1113 | "dependencies": { 1114 | "event-stream": "=3.3.4" 1115 | }, 1116 | "bin": { 1117 | "ps-tree": "bin/ps-tree.js" 1118 | }, 1119 | "engines": { 1120 | "node": ">= 0.10" 1121 | } 1122 | }, 1123 | "node_modules/pstree.remy": { 1124 | "version": "1.1.8", 1125 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1126 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1127 | "dev": true 1128 | }, 1129 | "node_modules/qs": { 1130 | "version": "6.11.0", 1131 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1132 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1133 | "dependencies": { 1134 | "side-channel": "^1.0.4" 1135 | }, 1136 | "engines": { 1137 | "node": ">=0.6" 1138 | }, 1139 | "funding": { 1140 | "url": "https://github.com/sponsors/ljharb" 1141 | } 1142 | }, 1143 | "node_modules/range-parser": { 1144 | "version": "1.2.1", 1145 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1146 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1147 | "engines": { 1148 | "node": ">= 0.6" 1149 | } 1150 | }, 1151 | "node_modules/raw-body": { 1152 | "version": "2.5.1", 1153 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 1154 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 1155 | "dependencies": { 1156 | "bytes": "3.1.2", 1157 | "http-errors": "2.0.0", 1158 | "iconv-lite": "0.4.24", 1159 | "unpipe": "1.0.0" 1160 | }, 1161 | "engines": { 1162 | "node": ">= 0.8" 1163 | } 1164 | }, 1165 | "node_modules/readdirp": { 1166 | "version": "3.6.0", 1167 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1168 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1169 | "dev": true, 1170 | "dependencies": { 1171 | "picomatch": "^2.2.1" 1172 | }, 1173 | "engines": { 1174 | "node": ">=8.10.0" 1175 | } 1176 | }, 1177 | "node_modules/retry-as-promised": { 1178 | "version": "7.0.4", 1179 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-7.0.4.tgz", 1180 | "integrity": "sha512-XgmCoxKWkDofwH8WddD0w85ZfqYz+ZHlr5yo+3YUCfycWawU56T5ckWXsScsj5B8tqUcIG67DxXByo3VUgiAdA==", 1181 | "dev": true 1182 | }, 1183 | "node_modules/safe-buffer": { 1184 | "version": "5.2.1", 1185 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1186 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1187 | "funding": [ 1188 | { 1189 | "type": "github", 1190 | "url": "https://github.com/sponsors/feross" 1191 | }, 1192 | { 1193 | "type": "patreon", 1194 | "url": "https://www.patreon.com/feross" 1195 | }, 1196 | { 1197 | "type": "consulting", 1198 | "url": "https://feross.org/support" 1199 | } 1200 | ] 1201 | }, 1202 | "node_modules/safer-buffer": { 1203 | "version": "2.1.2", 1204 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1205 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1206 | }, 1207 | "node_modules/semver": { 1208 | "version": "5.7.1", 1209 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1210 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1211 | "dev": true, 1212 | "bin": { 1213 | "semver": "bin/semver" 1214 | } 1215 | }, 1216 | "node_modules/send": { 1217 | "version": "0.18.0", 1218 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1219 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1220 | "dependencies": { 1221 | "debug": "2.6.9", 1222 | "depd": "2.0.0", 1223 | "destroy": "1.2.0", 1224 | "encodeurl": "~1.0.2", 1225 | "escape-html": "~1.0.3", 1226 | "etag": "~1.8.1", 1227 | "fresh": "0.5.2", 1228 | "http-errors": "2.0.0", 1229 | "mime": "1.6.0", 1230 | "ms": "2.1.3", 1231 | "on-finished": "2.4.1", 1232 | "range-parser": "~1.2.1", 1233 | "statuses": "2.0.1" 1234 | }, 1235 | "engines": { 1236 | "node": ">= 0.8.0" 1237 | } 1238 | }, 1239 | "node_modules/send/node_modules/ms": { 1240 | "version": "2.1.3", 1241 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1242 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1243 | }, 1244 | "node_modules/sequelize": { 1245 | "version": "6.31.0", 1246 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.31.0.tgz", 1247 | "integrity": "sha512-nCPVtv+QydBmb3Us2jCNAr1Dx3gST83VZxxrUQn/JAVFCOrmYOgUaPUz5bevummyNf30zfHsZhIKYAOD3ULfTA==", 1248 | "dev": true, 1249 | "funding": [ 1250 | { 1251 | "type": "opencollective", 1252 | "url": "https://opencollective.com/sequelize" 1253 | } 1254 | ], 1255 | "dependencies": { 1256 | "@types/debug": "^4.1.7", 1257 | "@types/validator": "^13.7.1", 1258 | "debug": "^4.3.3", 1259 | "dottie": "^2.0.2", 1260 | "inflection": "^1.13.2", 1261 | "lodash": "^4.17.21", 1262 | "moment": "^2.29.1", 1263 | "moment-timezone": "^0.5.35", 1264 | "pg-connection-string": "^2.5.0", 1265 | "retry-as-promised": "^7.0.3", 1266 | "semver": "^7.3.5", 1267 | "sequelize-pool": "^7.1.0", 1268 | "toposort-class": "^1.0.1", 1269 | "uuid": "^8.3.2", 1270 | "validator": "^13.7.0", 1271 | "wkx": "^0.5.0" 1272 | }, 1273 | "engines": { 1274 | "node": ">=10.0.0" 1275 | }, 1276 | "peerDependenciesMeta": { 1277 | "ibm_db": { 1278 | "optional": true 1279 | }, 1280 | "mariadb": { 1281 | "optional": true 1282 | }, 1283 | "mysql2": { 1284 | "optional": true 1285 | }, 1286 | "oracledb": { 1287 | "optional": true 1288 | }, 1289 | "pg": { 1290 | "optional": true 1291 | }, 1292 | "pg-hstore": { 1293 | "optional": true 1294 | }, 1295 | "snowflake-sdk": { 1296 | "optional": true 1297 | }, 1298 | "sqlite3": { 1299 | "optional": true 1300 | }, 1301 | "tedious": { 1302 | "optional": true 1303 | } 1304 | } 1305 | }, 1306 | "node_modules/sequelize-pool": { 1307 | "version": "7.1.0", 1308 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-7.1.0.tgz", 1309 | "integrity": "sha512-G9c0qlIWQSK29pR/5U2JF5dDQeqqHRragoyahj/Nx4KOOQ3CPPfzxnfqFPCSB7x5UgjOgnZ61nSxz+fjDpRlJg==", 1310 | "dev": true, 1311 | "engines": { 1312 | "node": ">= 10.0.0" 1313 | } 1314 | }, 1315 | "node_modules/sequelize/node_modules/debug": { 1316 | "version": "4.3.4", 1317 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1318 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1319 | "dev": true, 1320 | "dependencies": { 1321 | "ms": "2.1.2" 1322 | }, 1323 | "engines": { 1324 | "node": ">=6.0" 1325 | }, 1326 | "peerDependenciesMeta": { 1327 | "supports-color": { 1328 | "optional": true 1329 | } 1330 | } 1331 | }, 1332 | "node_modules/sequelize/node_modules/ms": { 1333 | "version": "2.1.2", 1334 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1335 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1336 | "dev": true 1337 | }, 1338 | "node_modules/sequelize/node_modules/semver": { 1339 | "version": "7.4.0", 1340 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.4.0.tgz", 1341 | "integrity": "sha512-RgOxM8Mw+7Zus0+zcLEUn8+JfoLpj/huFTItQy2hsM4khuC1HYRDp0cU482Ewn/Fcy6bCjufD8vAj7voC66KQw==", 1342 | "dev": true, 1343 | "dependencies": { 1344 | "lru-cache": "^6.0.0" 1345 | }, 1346 | "bin": { 1347 | "semver": "bin/semver.js" 1348 | }, 1349 | "engines": { 1350 | "node": ">=10" 1351 | } 1352 | }, 1353 | "node_modules/serve-static": { 1354 | "version": "1.15.0", 1355 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1356 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1357 | "dependencies": { 1358 | "encodeurl": "~1.0.2", 1359 | "escape-html": "~1.0.3", 1360 | "parseurl": "~1.3.3", 1361 | "send": "0.18.0" 1362 | }, 1363 | "engines": { 1364 | "node": ">= 0.8.0" 1365 | } 1366 | }, 1367 | "node_modules/setprototypeof": { 1368 | "version": "1.2.0", 1369 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1370 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1371 | }, 1372 | "node_modules/shebang-command": { 1373 | "version": "2.0.0", 1374 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1375 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1376 | "dependencies": { 1377 | "shebang-regex": "^3.0.0" 1378 | }, 1379 | "engines": { 1380 | "node": ">=8" 1381 | } 1382 | }, 1383 | "node_modules/shebang-regex": { 1384 | "version": "3.0.0", 1385 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1386 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1387 | "engines": { 1388 | "node": ">=8" 1389 | } 1390 | }, 1391 | "node_modules/side-channel": { 1392 | "version": "1.0.4", 1393 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1394 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1395 | "dependencies": { 1396 | "call-bind": "^1.0.0", 1397 | "get-intrinsic": "^1.0.2", 1398 | "object-inspect": "^1.9.0" 1399 | }, 1400 | "funding": { 1401 | "url": "https://github.com/sponsors/ljharb" 1402 | } 1403 | }, 1404 | "node_modules/simple-update-notifier": { 1405 | "version": "1.1.0", 1406 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.1.0.tgz", 1407 | "integrity": "sha512-VpsrsJSUcJEseSbMHkrsrAVSdvVS5I96Qo1QAQ4FxQ9wXFcB+pjj7FB7/us9+GcgfW4ziHtYMc1J0PLczb55mg==", 1408 | "dev": true, 1409 | "dependencies": { 1410 | "semver": "~7.0.0" 1411 | }, 1412 | "engines": { 1413 | "node": ">=8.10.0" 1414 | } 1415 | }, 1416 | "node_modules/simple-update-notifier/node_modules/semver": { 1417 | "version": "7.0.0", 1418 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 1419 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", 1420 | "dev": true, 1421 | "bin": { 1422 | "semver": "bin/semver.js" 1423 | } 1424 | }, 1425 | "node_modules/split": { 1426 | "version": "0.3.3", 1427 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 1428 | "integrity": "sha512-wD2AeVmxXRBoX44wAycgjVpMhvbwdI2aZjCkvfNcH1YqHQvJVa1duWc73OyVGJUc05fhFaTZeQ/PYsrmyH0JVA==", 1429 | "dev": true, 1430 | "dependencies": { 1431 | "through": "2" 1432 | }, 1433 | "engines": { 1434 | "node": "*" 1435 | } 1436 | }, 1437 | "node_modules/statuses": { 1438 | "version": "2.0.1", 1439 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1440 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1441 | "engines": { 1442 | "node": ">= 0.8" 1443 | } 1444 | }, 1445 | "node_modules/stream-combiner": { 1446 | "version": "0.0.4", 1447 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 1448 | "integrity": "sha512-rT00SPnTVyRsaSz5zgSPma/aHSOic5U1prhYdRy5HS2kTZviFpmDgzilbtsJsxiroqACmayynDN/9VzIbX5DOw==", 1449 | "dev": true, 1450 | "dependencies": { 1451 | "duplexer": "~0.1.1" 1452 | } 1453 | }, 1454 | "node_modules/string-argv": { 1455 | "version": "0.3.1", 1456 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 1457 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 1458 | "dev": true, 1459 | "engines": { 1460 | "node": ">=0.6.19" 1461 | } 1462 | }, 1463 | "node_modules/supports-color": { 1464 | "version": "5.5.0", 1465 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1466 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1467 | "dev": true, 1468 | "dependencies": { 1469 | "has-flag": "^3.0.0" 1470 | }, 1471 | "engines": { 1472 | "node": ">=4" 1473 | } 1474 | }, 1475 | "node_modules/through": { 1476 | "version": "2.3.8", 1477 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1478 | "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", 1479 | "dev": true 1480 | }, 1481 | "node_modules/to-regex-range": { 1482 | "version": "5.0.1", 1483 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1484 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1485 | "dev": true, 1486 | "dependencies": { 1487 | "is-number": "^7.0.0" 1488 | }, 1489 | "engines": { 1490 | "node": ">=8.0" 1491 | } 1492 | }, 1493 | "node_modules/toidentifier": { 1494 | "version": "1.0.1", 1495 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1496 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1497 | "engines": { 1498 | "node": ">=0.6" 1499 | } 1500 | }, 1501 | "node_modules/toposort-class": { 1502 | "version": "1.0.1", 1503 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 1504 | "integrity": "sha512-OsLcGGbYF3rMjPUf8oKktyvCiUxSbqMMS39m33MAjLTC1DVIH6x3WSt63/M77ihI09+Sdfk1AXvfhCEeUmC7mg==", 1505 | "dev": true 1506 | }, 1507 | "node_modules/touch": { 1508 | "version": "3.1.0", 1509 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1510 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1511 | "dev": true, 1512 | "dependencies": { 1513 | "nopt": "~1.0.10" 1514 | }, 1515 | "bin": { 1516 | "nodetouch": "bin/nodetouch.js" 1517 | } 1518 | }, 1519 | "node_modules/troveql": { 1520 | "version": "0.1.7", 1521 | "resolved": "https://registry.npmjs.org/troveql/-/troveql-0.1.7.tgz", 1522 | "integrity": "sha512-ZnTa5tpYE+BKq6H4Jp5n514gqMkUw7TuW90JbFNofyhasjzB4eSODPzee27GdyXIXHaDjesNIeCTAxURMd7slQ==", 1523 | "dependencies": { 1524 | "graphql": "^16.6.0" 1525 | } 1526 | }, 1527 | "node_modules/troveql/node_modules/graphql": { 1528 | "version": "16.6.0", 1529 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-16.6.0.tgz", 1530 | "integrity": "sha512-KPIBPDlW7NxrbT/eh4qPXz5FiFdL5UbaA0XUNz2Rp3Z3hqBSkbj0GVjwFDztsWVauZUWsbKHgMg++sk8UX0bkw==", 1531 | "engines": { 1532 | "node": "^12.22.0 || ^14.16.0 || ^16.0.0 || >=17.0.0" 1533 | } 1534 | }, 1535 | "node_modules/tsc-watch": { 1536 | "version": "6.0.0", 1537 | "resolved": "https://registry.npmjs.org/tsc-watch/-/tsc-watch-6.0.0.tgz", 1538 | "integrity": "sha512-zgpju+/z5z29/kK5V28Nz16CMkX2voFOUxkTlCim/R25hxzbyUqu2NfTnmJBQfESBSPbEQUGqDdB9A8opAcB4A==", 1539 | "dev": true, 1540 | "dependencies": { 1541 | "cross-spawn": "^7.0.3", 1542 | "node-cleanup": "^2.1.2", 1543 | "ps-tree": "^1.2.0", 1544 | "string-argv": "^0.3.1" 1545 | }, 1546 | "bin": { 1547 | "tsc-watch": "dist/lib/tsc-watch.js" 1548 | }, 1549 | "engines": { 1550 | "node": ">=12.12.0" 1551 | }, 1552 | "peerDependencies": { 1553 | "typescript": "*" 1554 | } 1555 | }, 1556 | "node_modules/tslib": { 1557 | "version": "2.5.0", 1558 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz", 1559 | "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==" 1560 | }, 1561 | "node_modules/type-is": { 1562 | "version": "1.6.18", 1563 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1564 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1565 | "dependencies": { 1566 | "media-typer": "0.3.0", 1567 | "mime-types": "~2.1.24" 1568 | }, 1569 | "engines": { 1570 | "node": ">= 0.6" 1571 | } 1572 | }, 1573 | "node_modules/typescript": { 1574 | "version": "5.0.2", 1575 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.2.tgz", 1576 | "integrity": "sha512-wVORMBGO/FAs/++blGNeAVdbNKtIh1rbBL2EyQ1+J9lClJ93KiiKe8PmFIVdXhHcyv44SL9oglmfeSsndo0jRw==", 1577 | "dev": true, 1578 | "bin": { 1579 | "tsc": "bin/tsc", 1580 | "tsserver": "bin/tsserver" 1581 | }, 1582 | "engines": { 1583 | "node": ">=12.20" 1584 | } 1585 | }, 1586 | "node_modules/undefsafe": { 1587 | "version": "2.0.5", 1588 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1589 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 1590 | "dev": true 1591 | }, 1592 | "node_modules/unpipe": { 1593 | "version": "1.0.0", 1594 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1595 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1596 | "engines": { 1597 | "node": ">= 0.8" 1598 | } 1599 | }, 1600 | "node_modules/utils-merge": { 1601 | "version": "1.0.1", 1602 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1603 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1604 | "engines": { 1605 | "node": ">= 0.4.0" 1606 | } 1607 | }, 1608 | "node_modules/uuid": { 1609 | "version": "8.3.2", 1610 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 1611 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 1612 | "dev": true, 1613 | "bin": { 1614 | "uuid": "dist/bin/uuid" 1615 | } 1616 | }, 1617 | "node_modules/validator": { 1618 | "version": "13.9.0", 1619 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.9.0.tgz", 1620 | "integrity": "sha512-B+dGG8U3fdtM0/aNK4/X8CXq/EcxU2WPrPEkJGslb47qyHsxmbggTWK0yEA4qnYVNF+nxNlN88o14hIcPmSIEA==", 1621 | "dev": true, 1622 | "engines": { 1623 | "node": ">= 0.10" 1624 | } 1625 | }, 1626 | "node_modules/value-or-promise": { 1627 | "version": "1.0.12", 1628 | "resolved": "https://registry.npmjs.org/value-or-promise/-/value-or-promise-1.0.12.tgz", 1629 | "integrity": "sha512-Z6Uz+TYwEqE7ZN50gwn+1LCVo9ZVrpxRPOhOLnncYkY1ZzOYtrX8Fwf/rFktZ8R5mJms6EZf5TqNOMeZmnPq9Q==", 1630 | "engines": { 1631 | "node": ">=12" 1632 | } 1633 | }, 1634 | "node_modules/vary": { 1635 | "version": "1.1.2", 1636 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1637 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1638 | "engines": { 1639 | "node": ">= 0.8" 1640 | } 1641 | }, 1642 | "node_modules/which": { 1643 | "version": "2.0.2", 1644 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1645 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1646 | "dependencies": { 1647 | "isexe": "^2.0.0" 1648 | }, 1649 | "bin": { 1650 | "node-which": "bin/node-which" 1651 | }, 1652 | "engines": { 1653 | "node": ">= 8" 1654 | } 1655 | }, 1656 | "node_modules/wkx": { 1657 | "version": "0.5.0", 1658 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz", 1659 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==", 1660 | "dev": true, 1661 | "dependencies": { 1662 | "@types/node": "*" 1663 | } 1664 | }, 1665 | "node_modules/yallist": { 1666 | "version": "4.0.0", 1667 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1668 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1669 | "dev": true 1670 | } 1671 | }, 1672 | "dependencies": { 1673 | "@graphql-tools/merge": { 1674 | "version": "8.4.0", 1675 | "resolved": "https://registry.npmjs.org/@graphql-tools/merge/-/merge-8.4.0.tgz", 1676 | "integrity": "sha512-3XYCWe0d3I4F1azNj1CdShlbHfTIfiDgj00R9uvFH8tHKh7i1IWN3F7QQYovcHKhayaR6zPok3YYMESYQcBoaA==", 1677 | "requires": { 1678 | "@graphql-tools/utils": "9.2.1", 1679 | "tslib": "^2.4.0" 1680 | } 1681 | }, 1682 | "@graphql-tools/schema": { 1683 | "version": "9.0.17", 1684 | "resolved": "https://registry.npmjs.org/@graphql-tools/schema/-/schema-9.0.17.tgz", 1685 | "integrity": "sha512-HVLq0ecbkuXhJlpZ50IHP5nlISqH2GbNgjBJhhRzHeXhfwlUOT4ISXGquWTmuq61K0xSaO0aCjMpxe4QYbKTng==", 1686 | "requires": { 1687 | "@graphql-tools/merge": "8.4.0", 1688 | "@graphql-tools/utils": "9.2.1", 1689 | "tslib": "^2.4.0", 1690 | "value-or-promise": "1.0.12" 1691 | } 1692 | }, 1693 | "@graphql-tools/utils": { 1694 | "version": "9.2.1", 1695 | "resolved": "https://registry.npmjs.org/@graphql-tools/utils/-/utils-9.2.1.tgz", 1696 | "integrity": "sha512-WUw506Ql6xzmOORlriNrD6Ugx+HjVgYxt9KCXD9mHAak+eaXSwuGGPyE60hy9xaDEoXKBsG7SkG69ybitaVl6A==", 1697 | "requires": { 1698 | "@graphql-typed-document-node/core": "^3.1.1", 1699 | "tslib": "^2.4.0" 1700 | } 1701 | }, 1702 | "@graphql-typed-document-node/core": { 1703 | "version": "3.2.0", 1704 | "resolved": "https://registry.npmjs.org/@graphql-typed-document-node/core/-/core-3.2.0.tgz", 1705 | "integrity": "sha512-mB9oAsNCm9aM3/SOv4YtBMqZbYj10R7dkq8byBqxGY/ncFwhf2oQzMV+LCRlWoDSEBJ3COiR1yeDvMtsoOsuFQ==", 1706 | "requires": {} 1707 | }, 1708 | "@types/body-parser": { 1709 | "version": "1.19.2", 1710 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 1711 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 1712 | "dev": true, 1713 | "requires": { 1714 | "@types/connect": "*", 1715 | "@types/node": "*" 1716 | } 1717 | }, 1718 | "@types/connect": { 1719 | "version": "3.4.35", 1720 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 1721 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 1722 | "dev": true, 1723 | "requires": { 1724 | "@types/node": "*" 1725 | } 1726 | }, 1727 | "@types/debug": { 1728 | "version": "4.1.7", 1729 | "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.7.tgz", 1730 | "integrity": "sha512-9AonUzyTjXXhEOa0DnqpzZi6VHlqKMswga9EXjpXnnqxwLtdvPPtlO8evrI5D9S6asFRCQ6v+wpiUKbw+vKqyg==", 1731 | "dev": true, 1732 | "requires": { 1733 | "@types/ms": "*" 1734 | } 1735 | }, 1736 | "@types/express": { 1737 | "version": "4.17.17", 1738 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.17.tgz", 1739 | "integrity": "sha512-Q4FmmuLGBG58btUnfS1c1r/NQdlp3DMfGDGig8WhfpA2YRUtEkxAjkZb0yvplJGYdF1fsQ81iMDcH24sSCNC/Q==", 1740 | "dev": true, 1741 | "requires": { 1742 | "@types/body-parser": "*", 1743 | "@types/express-serve-static-core": "^4.17.33", 1744 | "@types/qs": "*", 1745 | "@types/serve-static": "*" 1746 | } 1747 | }, 1748 | "@types/express-serve-static-core": { 1749 | "version": "4.17.33", 1750 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.33.tgz", 1751 | "integrity": "sha512-TPBqmR/HRYI3eC2E5hmiivIzv+bidAfXofM+sbonAGvyDhySGw9/PQZFt2BLOrjUUR++4eJVpx6KnLQK1Fk9tA==", 1752 | "dev": true, 1753 | "requires": { 1754 | "@types/node": "*", 1755 | "@types/qs": "*", 1756 | "@types/range-parser": "*" 1757 | } 1758 | }, 1759 | "@types/mime": { 1760 | "version": "3.0.1", 1761 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz", 1762 | "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==", 1763 | "dev": true 1764 | }, 1765 | "@types/ms": { 1766 | "version": "0.7.31", 1767 | "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", 1768 | "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==", 1769 | "dev": true 1770 | }, 1771 | "@types/node": { 1772 | "version": "18.15.9", 1773 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.15.9.tgz", 1774 | "integrity": "sha512-dUxhiNzBLr6IqlZXz6e/rN2YQXlFgOei/Dxy+e3cyXTJ4txSUbGT2/fmnD6zd/75jDMeW5bDee+YXxlFKHoV0A==", 1775 | "dev": true 1776 | }, 1777 | "@types/qs": { 1778 | "version": "6.9.7", 1779 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 1780 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 1781 | "dev": true 1782 | }, 1783 | "@types/range-parser": { 1784 | "version": "1.2.4", 1785 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 1786 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 1787 | "dev": true 1788 | }, 1789 | "@types/serve-static": { 1790 | "version": "1.15.1", 1791 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.1.tgz", 1792 | "integrity": "sha512-NUo5XNiAdULrJENtJXZZ3fHtfMolzZwczzBbnAeBbqBwG+LaG6YaJtuwzwGSQZ2wsCrxjEhNNjAkKigy3n8teQ==", 1793 | "dev": true, 1794 | "requires": { 1795 | "@types/mime": "*", 1796 | "@types/node": "*" 1797 | } 1798 | }, 1799 | "@types/validator": { 1800 | "version": "13.7.14", 1801 | "resolved": "https://registry.npmjs.org/@types/validator/-/validator-13.7.14.tgz", 1802 | "integrity": "sha512-J6OAed6rhN6zyqL9Of6ZMamhlsOEU/poBVvbHr/dKOYKTeuYYMlDkMv+b6UUV0o2i0tw73cgyv/97WTWaUl0/g==", 1803 | "dev": true 1804 | }, 1805 | "abbrev": { 1806 | "version": "1.1.1", 1807 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 1808 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 1809 | "dev": true 1810 | }, 1811 | "accepts": { 1812 | "version": "1.3.8", 1813 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 1814 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 1815 | "requires": { 1816 | "mime-types": "~2.1.34", 1817 | "negotiator": "0.6.3" 1818 | } 1819 | }, 1820 | "anymatch": { 1821 | "version": "3.1.3", 1822 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1823 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1824 | "dev": true, 1825 | "requires": { 1826 | "normalize-path": "^3.0.0", 1827 | "picomatch": "^2.0.4" 1828 | } 1829 | }, 1830 | "array-flatten": { 1831 | "version": "1.1.1", 1832 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 1833 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 1834 | }, 1835 | "balanced-match": { 1836 | "version": "1.0.2", 1837 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1838 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1839 | "dev": true 1840 | }, 1841 | "binary-extensions": { 1842 | "version": "2.2.0", 1843 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1844 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 1845 | "dev": true 1846 | }, 1847 | "body-parser": { 1848 | "version": "1.20.1", 1849 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 1850 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 1851 | "requires": { 1852 | "bytes": "3.1.2", 1853 | "content-type": "~1.0.4", 1854 | "debug": "2.6.9", 1855 | "depd": "2.0.0", 1856 | "destroy": "1.2.0", 1857 | "http-errors": "2.0.0", 1858 | "iconv-lite": "0.4.24", 1859 | "on-finished": "2.4.1", 1860 | "qs": "6.11.0", 1861 | "raw-body": "2.5.1", 1862 | "type-is": "~1.6.18", 1863 | "unpipe": "1.0.0" 1864 | } 1865 | }, 1866 | "brace-expansion": { 1867 | "version": "1.1.11", 1868 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1869 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1870 | "dev": true, 1871 | "requires": { 1872 | "balanced-match": "^1.0.0", 1873 | "concat-map": "0.0.1" 1874 | } 1875 | }, 1876 | "braces": { 1877 | "version": "3.0.2", 1878 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1879 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1880 | "dev": true, 1881 | "requires": { 1882 | "fill-range": "^7.0.1" 1883 | } 1884 | }, 1885 | "bytes": { 1886 | "version": "3.1.2", 1887 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 1888 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" 1889 | }, 1890 | "call-bind": { 1891 | "version": "1.0.2", 1892 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 1893 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 1894 | "requires": { 1895 | "function-bind": "^1.1.1", 1896 | "get-intrinsic": "^1.0.2" 1897 | } 1898 | }, 1899 | "chokidar": { 1900 | "version": "3.5.3", 1901 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 1902 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 1903 | "dev": true, 1904 | "requires": { 1905 | "anymatch": "~3.1.2", 1906 | "braces": "~3.0.2", 1907 | "fsevents": "~2.3.2", 1908 | "glob-parent": "~5.1.2", 1909 | "is-binary-path": "~2.1.0", 1910 | "is-glob": "~4.0.1", 1911 | "normalize-path": "~3.0.0", 1912 | "readdirp": "~3.6.0" 1913 | } 1914 | }, 1915 | "concat-map": { 1916 | "version": "0.0.1", 1917 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1918 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1919 | "dev": true 1920 | }, 1921 | "content-disposition": { 1922 | "version": "0.5.4", 1923 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 1924 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 1925 | "requires": { 1926 | "safe-buffer": "5.2.1" 1927 | } 1928 | }, 1929 | "content-type": { 1930 | "version": "1.0.5", 1931 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 1932 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==" 1933 | }, 1934 | "cookie": { 1935 | "version": "0.5.0", 1936 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 1937 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==" 1938 | }, 1939 | "cookie-signature": { 1940 | "version": "1.0.6", 1941 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 1942 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 1943 | }, 1944 | "cors": { 1945 | "version": "2.8.5", 1946 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 1947 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 1948 | "requires": { 1949 | "object-assign": "^4", 1950 | "vary": "^1" 1951 | } 1952 | }, 1953 | "cross-spawn": { 1954 | "version": "7.0.3", 1955 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1956 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1957 | "requires": { 1958 | "path-key": "^3.1.0", 1959 | "shebang-command": "^2.0.0", 1960 | "which": "^2.0.1" 1961 | } 1962 | }, 1963 | "debug": { 1964 | "version": "2.6.9", 1965 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1966 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1967 | "requires": { 1968 | "ms": "2.0.0" 1969 | } 1970 | }, 1971 | "depd": { 1972 | "version": "2.0.0", 1973 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 1974 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 1975 | }, 1976 | "destroy": { 1977 | "version": "1.2.0", 1978 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 1979 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" 1980 | }, 1981 | "dotenv": { 1982 | "version": "16.0.3", 1983 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 1984 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==" 1985 | }, 1986 | "dotenv-cli": { 1987 | "version": "7.2.1", 1988 | "resolved": "https://registry.npmjs.org/dotenv-cli/-/dotenv-cli-7.2.1.tgz", 1989 | "integrity": "sha512-ODHbGTskqRtXAzZapDPvgNuDVQApu4oKX8lZW7Y0+9hKA6le1ZJlyRS687oU9FXjOVEDU/VFV6zI125HzhM1UQ==", 1990 | "requires": { 1991 | "cross-spawn": "^7.0.3", 1992 | "dotenv": "^16.0.0", 1993 | "dotenv-expand": "^10.0.0", 1994 | "minimist": "^1.2.6" 1995 | } 1996 | }, 1997 | "dotenv-expand": { 1998 | "version": "10.0.0", 1999 | "resolved": "https://registry.npmjs.org/dotenv-expand/-/dotenv-expand-10.0.0.tgz", 2000 | "integrity": "sha512-GopVGCpVS1UKH75VKHGuQFqS1Gusej0z4FyQkPdwjil2gNIv+LNsqBlboOzpJFZKVT95GkCyWJbBSdFEFUWI2A==" 2001 | }, 2002 | "dottie": { 2003 | "version": "2.0.3", 2004 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.3.tgz", 2005 | "integrity": "sha512-4liA0PuRkZWQFQjwBypdxPfZaRWiv5tkhMXY2hzsa2pNf5s7U3m9cwUchfNKe8wZQxdGPQQzO6Rm2uGe0rvohQ==", 2006 | "dev": true 2007 | }, 2008 | "duplexer": { 2009 | "version": "0.1.2", 2010 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", 2011 | "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==", 2012 | "dev": true 2013 | }, 2014 | "ee-first": { 2015 | "version": "1.1.1", 2016 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 2017 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 2018 | }, 2019 | "encodeurl": { 2020 | "version": "1.0.2", 2021 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2022 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" 2023 | }, 2024 | "escape-html": { 2025 | "version": "1.0.3", 2026 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2027 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 2028 | }, 2029 | "etag": { 2030 | "version": "1.8.1", 2031 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 2032 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==" 2033 | }, 2034 | "event-stream": { 2035 | "version": "3.3.4", 2036 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 2037 | "integrity": "sha512-QHpkERcGsR0T7Qm3HNJSyXKEEj8AHNxkY3PK8TS2KJvQ7NiSHe3DDpwVKKtoYprL/AreyzFBeIkBIWChAqn60g==", 2038 | "dev": true, 2039 | "requires": { 2040 | "duplexer": "~0.1.1", 2041 | "from": "~0", 2042 | "map-stream": "~0.1.0", 2043 | "pause-stream": "0.0.11", 2044 | "split": "0.3", 2045 | "stream-combiner": "~0.0.4", 2046 | "through": "~2.3.1" 2047 | } 2048 | }, 2049 | "express": { 2050 | "version": "4.18.2", 2051 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 2052 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 2053 | "requires": { 2054 | "accepts": "~1.3.8", 2055 | "array-flatten": "1.1.1", 2056 | "body-parser": "1.20.1", 2057 | "content-disposition": "0.5.4", 2058 | "content-type": "~1.0.4", 2059 | "cookie": "0.5.0", 2060 | "cookie-signature": "1.0.6", 2061 | "debug": "2.6.9", 2062 | "depd": "2.0.0", 2063 | "encodeurl": "~1.0.2", 2064 | "escape-html": "~1.0.3", 2065 | "etag": "~1.8.1", 2066 | "finalhandler": "1.2.0", 2067 | "fresh": "0.5.2", 2068 | "http-errors": "2.0.0", 2069 | "merge-descriptors": "1.0.1", 2070 | "methods": "~1.1.2", 2071 | "on-finished": "2.4.1", 2072 | "parseurl": "~1.3.3", 2073 | "path-to-regexp": "0.1.7", 2074 | "proxy-addr": "~2.0.7", 2075 | "qs": "6.11.0", 2076 | "range-parser": "~1.2.1", 2077 | "safe-buffer": "5.2.1", 2078 | "send": "0.18.0", 2079 | "serve-static": "1.15.0", 2080 | "setprototypeof": "1.2.0", 2081 | "statuses": "2.0.1", 2082 | "type-is": "~1.6.18", 2083 | "utils-merge": "1.0.1", 2084 | "vary": "~1.1.2" 2085 | } 2086 | }, 2087 | "express-graphql": { 2088 | "version": "0.12.0", 2089 | "resolved": "https://registry.npmjs.org/express-graphql/-/express-graphql-0.12.0.tgz", 2090 | "integrity": "sha512-DwYaJQy0amdy3pgNtiTDuGGM2BLdj+YO2SgbKoLliCfuHv3VVTt7vNG/ZqK2hRYjtYHE2t2KB705EU94mE64zg==", 2091 | "requires": { 2092 | "accepts": "^1.3.7", 2093 | "content-type": "^1.0.4", 2094 | "http-errors": "1.8.0", 2095 | "raw-body": "^2.4.1" 2096 | }, 2097 | "dependencies": { 2098 | "depd": { 2099 | "version": "1.1.2", 2100 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 2101 | "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==" 2102 | }, 2103 | "http-errors": { 2104 | "version": "1.8.0", 2105 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.0.tgz", 2106 | "integrity": "sha512-4I8r0C5JDhT5VkvI47QktDW75rNlGVsUf/8hzjCC/wkWI/jdTRmBb9aI7erSG82r1bjKY3F6k28WnsVxB1C73A==", 2107 | "requires": { 2108 | "depd": "~1.1.2", 2109 | "inherits": "2.0.4", 2110 | "setprototypeof": "1.2.0", 2111 | "statuses": ">= 1.5.0 < 2", 2112 | "toidentifier": "1.0.0" 2113 | } 2114 | }, 2115 | "statuses": { 2116 | "version": "1.5.0", 2117 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2118 | "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==" 2119 | }, 2120 | "toidentifier": { 2121 | "version": "1.0.0", 2122 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 2123 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 2124 | } 2125 | } 2126 | }, 2127 | "fill-range": { 2128 | "version": "7.0.1", 2129 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2130 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2131 | "dev": true, 2132 | "requires": { 2133 | "to-regex-range": "^5.0.1" 2134 | } 2135 | }, 2136 | "finalhandler": { 2137 | "version": "1.2.0", 2138 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 2139 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 2140 | "requires": { 2141 | "debug": "2.6.9", 2142 | "encodeurl": "~1.0.2", 2143 | "escape-html": "~1.0.3", 2144 | "on-finished": "2.4.1", 2145 | "parseurl": "~1.3.3", 2146 | "statuses": "2.0.1", 2147 | "unpipe": "~1.0.0" 2148 | } 2149 | }, 2150 | "forwarded": { 2151 | "version": "0.2.0", 2152 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 2153 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 2154 | }, 2155 | "fresh": { 2156 | "version": "0.5.2", 2157 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 2158 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" 2159 | }, 2160 | "from": { 2161 | "version": "0.1.7", 2162 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 2163 | "integrity": "sha512-twe20eF1OxVxp/ML/kq2p1uc6KvFK/+vs8WjEbeKmV2He22MKm7YF2ANIt+EOqhJ5L3K/SuuPhk0hWQDjOM23g==", 2164 | "dev": true 2165 | }, 2166 | "fsevents": { 2167 | "version": "2.3.2", 2168 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2169 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2170 | "dev": true, 2171 | "optional": true 2172 | }, 2173 | "function-bind": { 2174 | "version": "1.1.1", 2175 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2176 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2177 | }, 2178 | "get-intrinsic": { 2179 | "version": "1.2.0", 2180 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.0.tgz", 2181 | "integrity": "sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==", 2182 | "requires": { 2183 | "function-bind": "^1.1.1", 2184 | "has": "^1.0.3", 2185 | "has-symbols": "^1.0.3" 2186 | } 2187 | }, 2188 | "glob-parent": { 2189 | "version": "5.1.2", 2190 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2191 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2192 | "dev": true, 2193 | "requires": { 2194 | "is-glob": "^4.0.1" 2195 | } 2196 | }, 2197 | "graphql": { 2198 | "version": "15.8.0", 2199 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-15.8.0.tgz", 2200 | "integrity": "sha512-5gghUc24tP9HRznNpV2+FIoq3xKkj5dTQqf4v0CpdPbFVwFkWoxOM+o+2OC9ZSvjEMTjfmG9QT+gcvggTwW1zw==", 2201 | "peer": true 2202 | }, 2203 | "has": { 2204 | "version": "1.0.3", 2205 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2206 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2207 | "requires": { 2208 | "function-bind": "^1.1.1" 2209 | } 2210 | }, 2211 | "has-flag": { 2212 | "version": "3.0.0", 2213 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2214 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2215 | "dev": true 2216 | }, 2217 | "has-symbols": { 2218 | "version": "1.0.3", 2219 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2220 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 2221 | }, 2222 | "http-errors": { 2223 | "version": "2.0.0", 2224 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 2225 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 2226 | "requires": { 2227 | "depd": "2.0.0", 2228 | "inherits": "2.0.4", 2229 | "setprototypeof": "1.2.0", 2230 | "statuses": "2.0.1", 2231 | "toidentifier": "1.0.1" 2232 | } 2233 | }, 2234 | "iconv-lite": { 2235 | "version": "0.4.24", 2236 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2237 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2238 | "requires": { 2239 | "safer-buffer": ">= 2.1.2 < 3" 2240 | } 2241 | }, 2242 | "ignore-by-default": { 2243 | "version": "1.0.1", 2244 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 2245 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", 2246 | "dev": true 2247 | }, 2248 | "inflection": { 2249 | "version": "1.13.4", 2250 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.4.tgz", 2251 | "integrity": "sha512-6I/HUDeYFfuNCVS3td055BaXBwKYuzw7K3ExVMStBowKo9oOAMJIXIHvdyR3iboTCp1b+1i5DSkIZTcwIktuDw==", 2252 | "dev": true 2253 | }, 2254 | "inherits": { 2255 | "version": "2.0.4", 2256 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2257 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2258 | }, 2259 | "ipaddr.js": { 2260 | "version": "1.9.1", 2261 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 2262 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 2263 | }, 2264 | "is-binary-path": { 2265 | "version": "2.1.0", 2266 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2267 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2268 | "dev": true, 2269 | "requires": { 2270 | "binary-extensions": "^2.0.0" 2271 | } 2272 | }, 2273 | "is-extglob": { 2274 | "version": "2.1.1", 2275 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2276 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2277 | "dev": true 2278 | }, 2279 | "is-glob": { 2280 | "version": "4.0.3", 2281 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2282 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2283 | "dev": true, 2284 | "requires": { 2285 | "is-extglob": "^2.1.1" 2286 | } 2287 | }, 2288 | "is-number": { 2289 | "version": "7.0.0", 2290 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2291 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2292 | "dev": true 2293 | }, 2294 | "isexe": { 2295 | "version": "2.0.0", 2296 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2297 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" 2298 | }, 2299 | "lodash": { 2300 | "version": "4.17.21", 2301 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2302 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 2303 | "dev": true 2304 | }, 2305 | "lru-cache": { 2306 | "version": "6.0.0", 2307 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2308 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2309 | "dev": true, 2310 | "requires": { 2311 | "yallist": "^4.0.0" 2312 | } 2313 | }, 2314 | "map-stream": { 2315 | "version": "0.1.0", 2316 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 2317 | "integrity": "sha512-CkYQrPYZfWnu/DAmVCpTSX/xHpKZ80eKh2lAkyA6AJTef6bW+6JpbQZN5rofum7da+SyN1bi5ctTm+lTfcCW3g==", 2318 | "dev": true 2319 | }, 2320 | "media-typer": { 2321 | "version": "0.3.0", 2322 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2323 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" 2324 | }, 2325 | "merge-descriptors": { 2326 | "version": "1.0.1", 2327 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 2328 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 2329 | }, 2330 | "methods": { 2331 | "version": "1.1.2", 2332 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2333 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==" 2334 | }, 2335 | "mime": { 2336 | "version": "1.6.0", 2337 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2338 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 2339 | }, 2340 | "mime-db": { 2341 | "version": "1.52.0", 2342 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2343 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 2344 | }, 2345 | "mime-types": { 2346 | "version": "2.1.35", 2347 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2348 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2349 | "requires": { 2350 | "mime-db": "1.52.0" 2351 | } 2352 | }, 2353 | "minimatch": { 2354 | "version": "3.1.2", 2355 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2356 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2357 | "dev": true, 2358 | "requires": { 2359 | "brace-expansion": "^1.1.7" 2360 | } 2361 | }, 2362 | "minimist": { 2363 | "version": "1.2.8", 2364 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2365 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==" 2366 | }, 2367 | "moment": { 2368 | "version": "2.29.4", 2369 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 2370 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 2371 | "dev": true 2372 | }, 2373 | "moment-timezone": { 2374 | "version": "0.5.43", 2375 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.43.tgz", 2376 | "integrity": "sha512-72j3aNyuIsDxdF1i7CEgV2FfxM1r6aaqJyLB2vwb33mXYyoyLly+F1zbWqhA3/bVIoJ4szlUoMbUnVdid32NUQ==", 2377 | "dev": true, 2378 | "requires": { 2379 | "moment": "^2.29.4" 2380 | } 2381 | }, 2382 | "ms": { 2383 | "version": "2.0.0", 2384 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2385 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 2386 | }, 2387 | "negotiator": { 2388 | "version": "0.6.3", 2389 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 2390 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 2391 | }, 2392 | "node-cleanup": { 2393 | "version": "2.1.2", 2394 | "resolved": "https://registry.npmjs.org/node-cleanup/-/node-cleanup-2.1.2.tgz", 2395 | "integrity": "sha512-qN8v/s2PAJwGUtr1/hYTpNKlD6Y9rc4p8KSmJXyGdYGZsDGKXrGThikLFP9OCHFeLeEpQzPwiAtdIvBLqm//Hw==", 2396 | "dev": true 2397 | }, 2398 | "nodemon": { 2399 | "version": "2.0.21", 2400 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.21.tgz", 2401 | "integrity": "sha512-djN/n2549DUtY33S7o1djRCd7dEm0kBnj9c7S9XVXqRUbuggN1MZH/Nqa+5RFQr63Fbefq37nFXAE9VU86yL1A==", 2402 | "dev": true, 2403 | "requires": { 2404 | "chokidar": "^3.5.2", 2405 | "debug": "^3.2.7", 2406 | "ignore-by-default": "^1.0.1", 2407 | "minimatch": "^3.1.2", 2408 | "pstree.remy": "^1.1.8", 2409 | "semver": "^5.7.1", 2410 | "simple-update-notifier": "^1.0.7", 2411 | "supports-color": "^5.5.0", 2412 | "touch": "^3.1.0", 2413 | "undefsafe": "^2.0.5" 2414 | }, 2415 | "dependencies": { 2416 | "debug": { 2417 | "version": "3.2.7", 2418 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 2419 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 2420 | "dev": true, 2421 | "requires": { 2422 | "ms": "^2.1.1" 2423 | } 2424 | }, 2425 | "ms": { 2426 | "version": "2.1.3", 2427 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2428 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2429 | "dev": true 2430 | } 2431 | } 2432 | }, 2433 | "nopt": { 2434 | "version": "1.0.10", 2435 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 2436 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 2437 | "dev": true, 2438 | "requires": { 2439 | "abbrev": "1" 2440 | } 2441 | }, 2442 | "normalize-path": { 2443 | "version": "3.0.0", 2444 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2445 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2446 | "dev": true 2447 | }, 2448 | "object-assign": { 2449 | "version": "4.1.1", 2450 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2451 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==" 2452 | }, 2453 | "object-inspect": { 2454 | "version": "1.12.3", 2455 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 2456 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==" 2457 | }, 2458 | "on-finished": { 2459 | "version": "2.4.1", 2460 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 2461 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 2462 | "requires": { 2463 | "ee-first": "1.1.1" 2464 | } 2465 | }, 2466 | "parseurl": { 2467 | "version": "1.3.3", 2468 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2469 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2470 | }, 2471 | "path-key": { 2472 | "version": "3.1.1", 2473 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2474 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==" 2475 | }, 2476 | "path-to-regexp": { 2477 | "version": "0.1.7", 2478 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2479 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 2480 | }, 2481 | "pause-stream": { 2482 | "version": "0.0.11", 2483 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 2484 | "integrity": "sha512-e3FBlXLmN/D1S+zHzanP4E/4Z60oFAa3O051qt1pxa7DEJWKAyil6upYVXCWadEnuoqa4Pkc9oUx9zsxYeRv8A==", 2485 | "dev": true, 2486 | "requires": { 2487 | "through": "~2.3" 2488 | } 2489 | }, 2490 | "pg-connection-string": { 2491 | "version": "2.5.0", 2492 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.5.0.tgz", 2493 | "integrity": "sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ==", 2494 | "dev": true 2495 | }, 2496 | "picomatch": { 2497 | "version": "2.3.1", 2498 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2499 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2500 | "dev": true 2501 | }, 2502 | "proxy-addr": { 2503 | "version": "2.0.7", 2504 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2505 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2506 | "requires": { 2507 | "forwarded": "0.2.0", 2508 | "ipaddr.js": "1.9.1" 2509 | } 2510 | }, 2511 | "ps-tree": { 2512 | "version": "1.2.0", 2513 | "resolved": "https://registry.npmjs.org/ps-tree/-/ps-tree-1.2.0.tgz", 2514 | "integrity": "sha512-0VnamPPYHl4uaU/nSFeZZpR21QAWRz+sRv4iW9+v/GS/J5U5iZB5BNN6J0RMoOvdx2gWM2+ZFMIm58q24e4UYA==", 2515 | "dev": true, 2516 | "requires": { 2517 | "event-stream": "=3.3.4" 2518 | } 2519 | }, 2520 | "pstree.remy": { 2521 | "version": "1.1.8", 2522 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 2523 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 2524 | "dev": true 2525 | }, 2526 | "qs": { 2527 | "version": "6.11.0", 2528 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 2529 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 2530 | "requires": { 2531 | "side-channel": "^1.0.4" 2532 | } 2533 | }, 2534 | "range-parser": { 2535 | "version": "1.2.1", 2536 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2537 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 2538 | }, 2539 | "raw-body": { 2540 | "version": "2.5.1", 2541 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 2542 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 2543 | "requires": { 2544 | "bytes": "3.1.2", 2545 | "http-errors": "2.0.0", 2546 | "iconv-lite": "0.4.24", 2547 | "unpipe": "1.0.0" 2548 | } 2549 | }, 2550 | "readdirp": { 2551 | "version": "3.6.0", 2552 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2553 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2554 | "dev": true, 2555 | "requires": { 2556 | "picomatch": "^2.2.1" 2557 | } 2558 | }, 2559 | "retry-as-promised": { 2560 | "version": "7.0.4", 2561 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-7.0.4.tgz", 2562 | "integrity": "sha512-XgmCoxKWkDofwH8WddD0w85ZfqYz+ZHlr5yo+3YUCfycWawU56T5ckWXsScsj5B8tqUcIG67DxXByo3VUgiAdA==", 2563 | "dev": true 2564 | }, 2565 | "safe-buffer": { 2566 | "version": "5.2.1", 2567 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2568 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2569 | }, 2570 | "safer-buffer": { 2571 | "version": "2.1.2", 2572 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2573 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2574 | }, 2575 | "semver": { 2576 | "version": "5.7.1", 2577 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2578 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 2579 | "dev": true 2580 | }, 2581 | "send": { 2582 | "version": "0.18.0", 2583 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 2584 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 2585 | "requires": { 2586 | "debug": "2.6.9", 2587 | "depd": "2.0.0", 2588 | "destroy": "1.2.0", 2589 | "encodeurl": "~1.0.2", 2590 | "escape-html": "~1.0.3", 2591 | "etag": "~1.8.1", 2592 | "fresh": "0.5.2", 2593 | "http-errors": "2.0.0", 2594 | "mime": "1.6.0", 2595 | "ms": "2.1.3", 2596 | "on-finished": "2.4.1", 2597 | "range-parser": "~1.2.1", 2598 | "statuses": "2.0.1" 2599 | }, 2600 | "dependencies": { 2601 | "ms": { 2602 | "version": "2.1.3", 2603 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2604 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2605 | } 2606 | } 2607 | }, 2608 | "sequelize": { 2609 | "version": "6.31.0", 2610 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.31.0.tgz", 2611 | "integrity": "sha512-nCPVtv+QydBmb3Us2jCNAr1Dx3gST83VZxxrUQn/JAVFCOrmYOgUaPUz5bevummyNf30zfHsZhIKYAOD3ULfTA==", 2612 | "dev": true, 2613 | "requires": { 2614 | "@types/debug": "^4.1.7", 2615 | "@types/validator": "^13.7.1", 2616 | "debug": "^4.3.3", 2617 | "dottie": "^2.0.2", 2618 | "inflection": "^1.13.2", 2619 | "lodash": "^4.17.21", 2620 | "moment": "^2.29.1", 2621 | "moment-timezone": "^0.5.35", 2622 | "pg-connection-string": "^2.5.0", 2623 | "retry-as-promised": "^7.0.3", 2624 | "semver": "^7.3.5", 2625 | "sequelize-pool": "^7.1.0", 2626 | "toposort-class": "^1.0.1", 2627 | "uuid": "^8.3.2", 2628 | "validator": "^13.7.0", 2629 | "wkx": "^0.5.0" 2630 | }, 2631 | "dependencies": { 2632 | "debug": { 2633 | "version": "4.3.4", 2634 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2635 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2636 | "dev": true, 2637 | "requires": { 2638 | "ms": "2.1.2" 2639 | } 2640 | }, 2641 | "ms": { 2642 | "version": "2.1.2", 2643 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2644 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2645 | "dev": true 2646 | }, 2647 | "semver": { 2648 | "version": "7.4.0", 2649 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.4.0.tgz", 2650 | "integrity": "sha512-RgOxM8Mw+7Zus0+zcLEUn8+JfoLpj/huFTItQy2hsM4khuC1HYRDp0cU482Ewn/Fcy6bCjufD8vAj7voC66KQw==", 2651 | "dev": true, 2652 | "requires": { 2653 | "lru-cache": "^6.0.0" 2654 | } 2655 | } 2656 | } 2657 | }, 2658 | "sequelize-pool": { 2659 | "version": "7.1.0", 2660 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-7.1.0.tgz", 2661 | "integrity": "sha512-G9c0qlIWQSK29pR/5U2JF5dDQeqqHRragoyahj/Nx4KOOQ3CPPfzxnfqFPCSB7x5UgjOgnZ61nSxz+fjDpRlJg==", 2662 | "dev": true 2663 | }, 2664 | "serve-static": { 2665 | "version": "1.15.0", 2666 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 2667 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 2668 | "requires": { 2669 | "encodeurl": "~1.0.2", 2670 | "escape-html": "~1.0.3", 2671 | "parseurl": "~1.3.3", 2672 | "send": "0.18.0" 2673 | } 2674 | }, 2675 | "setprototypeof": { 2676 | "version": "1.2.0", 2677 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 2678 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 2679 | }, 2680 | "shebang-command": { 2681 | "version": "2.0.0", 2682 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2683 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2684 | "requires": { 2685 | "shebang-regex": "^3.0.0" 2686 | } 2687 | }, 2688 | "shebang-regex": { 2689 | "version": "3.0.0", 2690 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2691 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==" 2692 | }, 2693 | "side-channel": { 2694 | "version": "1.0.4", 2695 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2696 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2697 | "requires": { 2698 | "call-bind": "^1.0.0", 2699 | "get-intrinsic": "^1.0.2", 2700 | "object-inspect": "^1.9.0" 2701 | } 2702 | }, 2703 | "simple-update-notifier": { 2704 | "version": "1.1.0", 2705 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.1.0.tgz", 2706 | "integrity": "sha512-VpsrsJSUcJEseSbMHkrsrAVSdvVS5I96Qo1QAQ4FxQ9wXFcB+pjj7FB7/us9+GcgfW4ziHtYMc1J0PLczb55mg==", 2707 | "dev": true, 2708 | "requires": { 2709 | "semver": "~7.0.0" 2710 | }, 2711 | "dependencies": { 2712 | "semver": { 2713 | "version": "7.0.0", 2714 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 2715 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", 2716 | "dev": true 2717 | } 2718 | } 2719 | }, 2720 | "split": { 2721 | "version": "0.3.3", 2722 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 2723 | "integrity": "sha512-wD2AeVmxXRBoX44wAycgjVpMhvbwdI2aZjCkvfNcH1YqHQvJVa1duWc73OyVGJUc05fhFaTZeQ/PYsrmyH0JVA==", 2724 | "dev": true, 2725 | "requires": { 2726 | "through": "2" 2727 | } 2728 | }, 2729 | "statuses": { 2730 | "version": "2.0.1", 2731 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 2732 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" 2733 | }, 2734 | "stream-combiner": { 2735 | "version": "0.0.4", 2736 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 2737 | "integrity": "sha512-rT00SPnTVyRsaSz5zgSPma/aHSOic5U1prhYdRy5HS2kTZviFpmDgzilbtsJsxiroqACmayynDN/9VzIbX5DOw==", 2738 | "dev": true, 2739 | "requires": { 2740 | "duplexer": "~0.1.1" 2741 | } 2742 | }, 2743 | "string-argv": { 2744 | "version": "0.3.1", 2745 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 2746 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 2747 | "dev": true 2748 | }, 2749 | "supports-color": { 2750 | "version": "5.5.0", 2751 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2752 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2753 | "dev": true, 2754 | "requires": { 2755 | "has-flag": "^3.0.0" 2756 | } 2757 | }, 2758 | "through": { 2759 | "version": "2.3.8", 2760 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2761 | "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", 2762 | "dev": true 2763 | }, 2764 | "to-regex-range": { 2765 | "version": "5.0.1", 2766 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2767 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2768 | "dev": true, 2769 | "requires": { 2770 | "is-number": "^7.0.0" 2771 | } 2772 | }, 2773 | "toidentifier": { 2774 | "version": "1.0.1", 2775 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 2776 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 2777 | }, 2778 | "toposort-class": { 2779 | "version": "1.0.1", 2780 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 2781 | "integrity": "sha512-OsLcGGbYF3rMjPUf8oKktyvCiUxSbqMMS39m33MAjLTC1DVIH6x3WSt63/M77ihI09+Sdfk1AXvfhCEeUmC7mg==", 2782 | "dev": true 2783 | }, 2784 | "touch": { 2785 | "version": "3.1.0", 2786 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2787 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2788 | "dev": true, 2789 | "requires": { 2790 | "nopt": "~1.0.10" 2791 | } 2792 | }, 2793 | "troveql": { 2794 | "version": "0.1.7", 2795 | "resolved": "https://registry.npmjs.org/troveql/-/troveql-0.1.7.tgz", 2796 | "integrity": "sha512-ZnTa5tpYE+BKq6H4Jp5n514gqMkUw7TuW90JbFNofyhasjzB4eSODPzee27GdyXIXHaDjesNIeCTAxURMd7slQ==", 2797 | "requires": { 2798 | "graphql": "^16.6.0" 2799 | }, 2800 | "dependencies": { 2801 | "graphql": { 2802 | "version": "16.6.0", 2803 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-16.6.0.tgz", 2804 | "integrity": "sha512-KPIBPDlW7NxrbT/eh4qPXz5FiFdL5UbaA0XUNz2Rp3Z3hqBSkbj0GVjwFDztsWVauZUWsbKHgMg++sk8UX0bkw==" 2805 | } 2806 | } 2807 | }, 2808 | "tsc-watch": { 2809 | "version": "6.0.0", 2810 | "resolved": "https://registry.npmjs.org/tsc-watch/-/tsc-watch-6.0.0.tgz", 2811 | "integrity": "sha512-zgpju+/z5z29/kK5V28Nz16CMkX2voFOUxkTlCim/R25hxzbyUqu2NfTnmJBQfESBSPbEQUGqDdB9A8opAcB4A==", 2812 | "dev": true, 2813 | "requires": { 2814 | "cross-spawn": "^7.0.3", 2815 | "node-cleanup": "^2.1.2", 2816 | "ps-tree": "^1.2.0", 2817 | "string-argv": "^0.3.1" 2818 | } 2819 | }, 2820 | "tslib": { 2821 | "version": "2.5.0", 2822 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz", 2823 | "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==" 2824 | }, 2825 | "type-is": { 2826 | "version": "1.6.18", 2827 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2828 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2829 | "requires": { 2830 | "media-typer": "0.3.0", 2831 | "mime-types": "~2.1.24" 2832 | } 2833 | }, 2834 | "typescript": { 2835 | "version": "5.0.2", 2836 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.2.tgz", 2837 | "integrity": "sha512-wVORMBGO/FAs/++blGNeAVdbNKtIh1rbBL2EyQ1+J9lClJ93KiiKe8PmFIVdXhHcyv44SL9oglmfeSsndo0jRw==", 2838 | "dev": true 2839 | }, 2840 | "undefsafe": { 2841 | "version": "2.0.5", 2842 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 2843 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 2844 | "dev": true 2845 | }, 2846 | "unpipe": { 2847 | "version": "1.0.0", 2848 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2849 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==" 2850 | }, 2851 | "utils-merge": { 2852 | "version": "1.0.1", 2853 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2854 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==" 2855 | }, 2856 | "uuid": { 2857 | "version": "8.3.2", 2858 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 2859 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 2860 | "dev": true 2861 | }, 2862 | "validator": { 2863 | "version": "13.9.0", 2864 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.9.0.tgz", 2865 | "integrity": "sha512-B+dGG8U3fdtM0/aNK4/X8CXq/EcxU2WPrPEkJGslb47qyHsxmbggTWK0yEA4qnYVNF+nxNlN88o14hIcPmSIEA==", 2866 | "dev": true 2867 | }, 2868 | "value-or-promise": { 2869 | "version": "1.0.12", 2870 | "resolved": "https://registry.npmjs.org/value-or-promise/-/value-or-promise-1.0.12.tgz", 2871 | "integrity": "sha512-Z6Uz+TYwEqE7ZN50gwn+1LCVo9ZVrpxRPOhOLnncYkY1ZzOYtrX8Fwf/rFktZ8R5mJms6EZf5TqNOMeZmnPq9Q==" 2872 | }, 2873 | "vary": { 2874 | "version": "1.1.2", 2875 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2876 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==" 2877 | }, 2878 | "which": { 2879 | "version": "2.0.2", 2880 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2881 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2882 | "requires": { 2883 | "isexe": "^2.0.0" 2884 | } 2885 | }, 2886 | "wkx": { 2887 | "version": "0.5.0", 2888 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz", 2889 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==", 2890 | "dev": true, 2891 | "requires": { 2892 | "@types/node": "*" 2893 | } 2894 | }, 2895 | "yallist": { 2896 | "version": "4.0.0", 2897 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2898 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2899 | "dev": true 2900 | } 2901 | } 2902 | } 2903 | --------------------------------------------------------------------------------