├── .gitignore ├── .gitignore.bak ├── config └── config.json ├── controllers ├── departmentController.js └── userController.js ├── migrations ├── 20230730073239-create-department.js ├── 20230730073452-create-project.js ├── 20230730073453-create-user.js ├── skillMigration.js └── userSkillMapMigration.js ├── models ├── department.js ├── index.js ├── project.js ├── skill.js ├── user.js └── userSkillMap.js ├── package-lock.json ├── package.json ├── query.js ├── repositories ├── departmentRepo.js └── userRepo.js ├── routes ├── departmentRoutes.js └── userRoutes.js ├── schemaValidation └── userSchema.js ├── seeders ├── 20230730132300-demo-departments.js ├── 20230730132902-demo-projects.js └── 20230730140759-demo-users.js └── server.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ -------------------------------------------------------------------------------- /.gitignore.bak: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/001-mak/Sequelize-Postgres-Database/3c340312f147be387c6616653361f95c3ae4b7f9/.gitignore.bak -------------------------------------------------------------------------------- /config/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "development": { 3 | "username": "postgres", 4 | "password": "admin", 5 | "database": "sequelize", 6 | "host": "localhost", 7 | "dialect": "postgres" 8 | }, 9 | "test": { 10 | "username": "postgres", 11 | "password": "admin", 12 | "database": "sequelize", 13 | "host": "127.0.0.1", 14 | "dialect": "postgres" 15 | }, 16 | "production": { 17 | "username": "postgres", 18 | "password": "admin", 19 | "database": "sequelize", 20 | "host": "127.0.0.1", 21 | "dialect": "postgres" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /controllers/departmentController.js: -------------------------------------------------------------------------------- 1 | const { 2 | getDepartmentsRepo, 3 | getDepartmentRepo, 4 | createDepartmentRepo, 5 | deleteDepartmentRepo, 6 | updateDepartmentRepo, 7 | } = require("../repositories/departmentRepo"); 8 | 9 | const getDepartments = async (req, res) => { 10 | // try { 11 | const departments = await getDepartmentsRepo(); 12 | res.status(200).send(departments); 13 | // } catch (error) { 14 | // console.log(error); 15 | // } 16 | }; 17 | 18 | const createDepartment = async (req, res) => { 19 | try { 20 | const department = await createDepartmentRepo(req.body); 21 | res.status(200).send(department); 22 | } catch (error) { 23 | console.log(error); 24 | } 25 | }; 26 | 27 | module.exports = { getDepartments, createDepartment }; 28 | -------------------------------------------------------------------------------- /controllers/userController.js: -------------------------------------------------------------------------------- 1 | const {getUsersRepo} = require('../repositories/userRepo') 2 | 3 | const getUsers = async (req, res) => { 4 | try { 5 | const users = await getUsersRepo(); 6 | res.status(200).send(users); 7 | } catch (error) { 8 | res.status(500).send("Error"); 9 | } 10 | 11 | }; 12 | 13 | const createUser = (req, res) => { 14 | console.log("User Created"); 15 | }; 16 | 17 | const updateUser = (req, res) => { 18 | console.log("User Updated"); 19 | }; 20 | const deleteUser = (req, res) => { 21 | console.log("User Deleted"); 22 | }; 23 | 24 | module.exports = { getUsers, createUser, updateUser, deleteUser }; 25 | -------------------------------------------------------------------------------- /migrations/20230730073239-create-department.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | /** @type {import('sequelize-cli').Migration} */ 3 | module.exports = { 4 | async up(queryInterface, Sequelize) { 5 | await queryInterface.createTable('Departments', { 6 | id: { 7 | type: Sequelize.INTEGER, 8 | autoIncrement:true, 9 | allowNull: false, 10 | primaryKey: true, 11 | }, 12 | departmentName: { 13 | type: Sequelize.STRING, 14 | allowNull: false, 15 | }, 16 | phone: { 17 | type: Sequelize.STRING, 18 | allowNull: false, 19 | }, 20 | createdAt:{ 21 | type: Sequelize.DATE(), 22 | allowNull:true, 23 | defaultValue: new Date() 24 | }, 25 | updatedAt:{ 26 | type: Sequelize.DATE(), 27 | allowNull:true, 28 | defaultValue: new Date() 29 | } 30 | }); 31 | }, 32 | async down(queryInterface, Sequelize) { 33 | await queryInterface.dropTable('Departments'); 34 | } 35 | }; -------------------------------------------------------------------------------- /migrations/20230730073452-create-project.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | /** @type {import('sequelize-cli').Migration} */ 3 | module.exports = { 4 | async up(queryInterface, Sequelize) { 5 | await queryInterface.createTable('Projects', { 6 | id: { 7 | type: Sequelize.INTEGER, 8 | autoIncrement:true, 9 | allowNull: false, 10 | primaryKey: true, 11 | }, 12 | projectName: { 13 | type: Sequelize.STRING, 14 | allowNull: false, 15 | }, 16 | departmentId: { 17 | type: Sequelize.INTEGER, 18 | allowNull:false, 19 | references:{ 20 | model: 'Departments', 21 | key: 'id' 22 | } 23 | }, 24 | createdAt:{ 25 | type: Sequelize.DATE(), 26 | allowNull:true, 27 | defaultValue: new Date() 28 | }, 29 | updatedAt:{ 30 | type: Sequelize.DATE(), 31 | allowNull:true, 32 | defaultValue: new Date() 33 | } 34 | 35 | }); 36 | }, 37 | async down(queryInterface, Sequelize) { 38 | await queryInterface.dropTable('Projects'); 39 | } 40 | }; -------------------------------------------------------------------------------- /migrations/20230730073453-create-user.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | /** @type {import('sequelize-cli').Migration} */ 3 | 4 | module.exports = { 5 | async up(queryInterface, Sequelize) { 6 | await queryInterface.createTable('Users', { 7 | id: { 8 | type: Sequelize.INTEGER, 9 | autoIncrement:true, 10 | allowNull: false, 11 | primaryKey: true, 12 | }, 13 | firstName: { 14 | type: Sequelize.STRING, 15 | }, 16 | lastName: { 17 | type: Sequelize.STRING, 18 | }, 19 | departmentId: { 20 | type: Sequelize.INTEGER, 21 | allowNull: false, 22 | references: { 23 | model: "Departments", 24 | key: "id", 25 | }, 26 | }, 27 | projectId: { 28 | type: Sequelize.INTEGER, 29 | allowNull: false, 30 | references: { 31 | model: "Projects", 32 | key: "id", 33 | }, 34 | }, 35 | createdAt:{ 36 | type: Sequelize.DATE(), 37 | allowNull:true, 38 | defaultValue: new Date() 39 | }, 40 | updatedAt:{ 41 | type: Sequelize.DATE(), 42 | allowNull:true, 43 | defaultValue: new Date() 44 | } 45 | }, 46 | ); 47 | }, 48 | async down(queryInterface, Sequelize) { 49 | await queryInterface.dropTable('Users'); 50 | } 51 | }; -------------------------------------------------------------------------------- /migrations/skillMigration.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | /** @type {import('sequelize-cli').Migration} */ 3 | module.exports = { 4 | async up(queryInterface, Sequelize) { 5 | await queryInterface.createTable( 6 | "Skills", 7 | { 8 | id: { 9 | type: Sequelize.INTEGER, 10 | autoIncrement: true, 11 | allowNull: false, 12 | primaryKey: true, 13 | }, 14 | skillName: { 15 | type: Sequelize.STRING, 16 | allowNull: false, 17 | }, 18 | createdAt:{ 19 | type: Sequelize.DATE(), 20 | allowNull:true, 21 | defaultValue: new Date() 22 | }, 23 | updatedAt:{ 24 | type: Sequelize.DATE(), 25 | allowNull:true, 26 | defaultValue: new Date() 27 | } 28 | }, 29 | 30 | ); 31 | }, 32 | async down(queryInterface, Sequelize) { 33 | await queryInterface.dropTable("Skills"); 34 | }, 35 | }; 36 | -------------------------------------------------------------------------------- /migrations/userSkillMapMigration.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | /** @type {import('sequelize-cli').Migration} */ 3 | module.exports = { 4 | async up(queryInterface, Sequelize) { 5 | await queryInterface.createTable( 6 | "UserSkillMaps", 7 | { 8 | userId: { 9 | type: Sequelize.INTEGER, 10 | autoIncrement: true, 11 | allowNull: false, 12 | references: { 13 | model: "Users", 14 | key: "id", 15 | }, 16 | }, 17 | skillId: { 18 | type: Sequelize.INTEGER, 19 | allowNull: false, 20 | references: { 21 | model: "Skills", 22 | key: "id", 23 | }, 24 | }, 25 | createdAt:{ 26 | type: Sequelize.DATE(), 27 | allowNull:true, 28 | defaultValue: new Date() 29 | }, 30 | updatedAt:{ 31 | type: Sequelize.DATE(), 32 | allowNull:true, 33 | defaultValue: new Date() 34 | } 35 | }, 36 | 37 | ); 38 | }, 39 | async down(queryInterface, Sequelize) { 40 | await queryInterface.dropTable("UserSkillMaps"); 41 | }, 42 | }; 43 | -------------------------------------------------------------------------------- /models/department.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const { Model } = require('sequelize'); 3 | const Sequelize = require('sequelize') 4 | 5 | // const User = require('./user') 6 | // const Project = require('./project') 7 | 8 | module.exports = (sequelize, DataTypes) => { 9 | class Department extends Model { 10 | /** 11 | * Helper method for defining associations. 12 | * This method is not a part of Sequelize lifecycle. 13 | * The `models/index` file will call this method automatically. 14 | */ 15 | static associate(models) { 16 | // define association here 17 | } 18 | } 19 | Department.init({ 20 | id: { 21 | type: Sequelize.UUIDV4, //UUIDV4 for generating random ID 22 | allowNull: false, 23 | primaryKey: true, 24 | }, 25 | departmentName: { 26 | type: Sequelize.STRING, 27 | allowNull: false, 28 | }, 29 | phone: { 30 | type: Sequelize.STRING, 31 | allowNull: false, 32 | }, 33 | }, { 34 | sequelize, 35 | modelName: 'Department', 36 | tableName: 'Departments', 37 | }); 38 | return Department; 39 | }; -------------------------------------------------------------------------------- /models/index.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const fs = require('fs'); 4 | const path = require('path'); 5 | const Sequelize = require('sequelize'); 6 | const process = require('process'); 7 | const basename = path.basename(__filename); 8 | const env = process.env.NODE_ENV || 'development'; 9 | const config = require(__dirname + '/../config/config.json')[env]; 10 | const db = {}; 11 | 12 | let sequelize; 13 | if (config.use_env_variable) { 14 | sequelize = new Sequelize(process.env[config.use_env_variable], config); 15 | } else { 16 | sequelize = new Sequelize(config.database, config.username, config.password, config); 17 | } 18 | 19 | fs 20 | .readdirSync(__dirname) 21 | .filter(file => { 22 | return ( 23 | file.indexOf('.') !== 0 && 24 | file !== basename && 25 | file.slice(-3) === '.js' && 26 | file.indexOf('.test.js') === -1 27 | ); 28 | }) 29 | .forEach(file => { 30 | const model = require(path.join(__dirname, file))(sequelize, Sequelize.DataTypes); 31 | db[model.name] = model; 32 | }); 33 | 34 | Object.keys(db).forEach(modelName => { 35 | if (db[modelName].associate) { 36 | db[modelName].associate(db); 37 | } 38 | }); 39 | 40 | db.sequelize = sequelize; 41 | db.Sequelize = Sequelize; 42 | 43 | module.exports = db; -------------------------------------------------------------------------------- /models/project.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const { Model } = require('sequelize'); 3 | const Sequelize = require('sequelize'); 4 | 5 | module.exports = (sequelize, DataTypes) => { 6 | class Project extends Model { 7 | /** 8 | * Helper method for defining associations. 9 | * This method is not a part of Sequelize lifecycle. 10 | * The `models/index` file will call this method automatically. 11 | */ 12 | static associate(models) { 13 | // define association here 14 | // this.hasMany(models.User) 15 | // models.User.belongsTo(this,{as:'projectId'}) 16 | 17 | } 18 | } 19 | Project.init({ 20 | id: { 21 | type: Sequelize.UUIDV4, //UUIDV4 for generating random ID 22 | allowNull: false, 23 | primaryKey: true, 24 | }, 25 | projectName: { 26 | type: Sequelize.STRING, 27 | allowNull: false, 28 | }, 29 | departmentId: { 30 | type: Sequelize.INTEGER, 31 | allowNull:false, 32 | references:{ 33 | model: 'Departments', 34 | key: 'id' 35 | } 36 | }, 37 | 38 | }, { 39 | sequelize, 40 | modelName: 'Project', 41 | tableName: 'Projects', 42 | }); 43 | return Project; 44 | }; -------------------------------------------------------------------------------- /models/skill.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const { Model } = require('sequelize'); 3 | const Sequelize = require('sequelize'); 4 | 5 | module.exports = (sequelize, DataTypes) => { 6 | class Skill extends Model { 7 | /** 8 | * Helper method for defining associations. 9 | * This method is not a part of Sequelize lifecycle. 10 | * The `models/index` file will call this method automatically. 11 | */ 12 | static associate(models) { 13 | // define association here 14 | } 15 | } 16 | Skill.init({ 17 | id: { 18 | type: Sequelize.UUIDV4, //UUIDV4 for generating random ID 19 | allowNull: false, 20 | primaryKey: true, 21 | }, 22 | skillName: { 23 | type: Sequelize.STRING, 24 | allowNull: false, 25 | }, 26 | }, { 27 | sequelize, 28 | modelName: 'Skill', 29 | tableName: 'Skills', 30 | }); 31 | return Skill; 32 | }; -------------------------------------------------------------------------------- /models/user.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | const Sequelize = require("sequelize"); 3 | 4 | const { Model } = require("sequelize"); 5 | module.exports = (sequelize, DataTypes) => { 6 | class User extends Model { 7 | /** 8 | * Helper method for defining associations. 9 | * This method is not a part of Sequelize lifecycle. 10 | * The `models/index` file will call this method automatically. 11 | */ 12 | static associate(models) {} 13 | } 14 | User.init( 15 | { 16 | id: { 17 | type: Sequelize.UUIDV4, 18 | allowNull: false, 19 | primaryKey: true, 20 | }, 21 | firstName: { 22 | type: Sequelize.STRING, 23 | }, 24 | lastName: { 25 | type: Sequelize.STRING, 26 | }, 27 | departmentId: { 28 | type: Sequelize.UUIDV4, 29 | allowNull: false, 30 | references: { 31 | model: "Departments", 32 | key: "id", 33 | }, 34 | }, 35 | projectId: { 36 | type: Sequelize.UUIDV4, 37 | allowNull: false, 38 | references: { 39 | model: "Projects", 40 | key: "id", 41 | }, 42 | }, 43 | }, 44 | { 45 | sequelize, 46 | modelName: "User", 47 | tableName: "Users", 48 | } 49 | ); 50 | return User; 51 | }; 52 | -------------------------------------------------------------------------------- /models/userSkillMap.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const { Model } = require('sequelize'); 3 | const Sequelize = require('sequelize'); 4 | 5 | module.exports = (sequelize, DataTypes) => { 6 | class userSkillMap extends Model { 7 | /** 8 | * Helper method for defining associations. 9 | * This method is not a part of Sequelize lifecycle. 10 | * The `models/index` file will call this method automatically. 11 | */ 12 | static associate(models) { 13 | // define association here 14 | } 15 | } 16 | userSkillMap.init({ 17 | userId: { 18 | type: Sequelize.UUIDV4, 19 | allowNull: false, 20 | references: { 21 | model: "Users", 22 | key: "id", 23 | }, 24 | }, 25 | skillId: { 26 | type: Sequelize.UUIDV4, 27 | allowNull: false, 28 | references: { 29 | model: "Skills", 30 | key: "id", 31 | }, 32 | }, 33 | }, { 34 | sequelize, 35 | modelName: 'UserSkillMap', 36 | tableName: 'UserSkillMaps', 37 | }); 38 | return userSkillMap; 39 | }; -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "seque", 3 | "lockfileVersion": 3, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "dependencies": { 8 | "express": "^4.18.2", 9 | "joi": "^17.9.2", 10 | "nodemon": "^3.0.1", 11 | "pg": "^8.11.1", 12 | "pg-hstore": "^2.3.4", 13 | "sequelize": "^6.32.1", 14 | "sequelize-cli": "^6.6.1", 15 | "uuidv4": "^6.2.13" 16 | } 17 | }, 18 | "node_modules/@hapi/hoek": { 19 | "version": "9.3.0", 20 | "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", 21 | "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==" 22 | }, 23 | "node_modules/@hapi/topo": { 24 | "version": "5.1.0", 25 | "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", 26 | "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", 27 | "dependencies": { 28 | "@hapi/hoek": "^9.0.0" 29 | } 30 | }, 31 | "node_modules/@one-ini/wasm": { 32 | "version": "0.1.1", 33 | "resolved": "https://registry.npmjs.org/@one-ini/wasm/-/wasm-0.1.1.tgz", 34 | "integrity": "sha512-XuySG1E38YScSJoMlqovLru4KTUNSjgVTIjyh7qMX6aNN5HY5Ct5LhRJdxO79JtTzKfzV/bnWpz+zquYrISsvw==" 35 | }, 36 | "node_modules/@sideway/address": { 37 | "version": "4.1.4", 38 | "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.4.tgz", 39 | "integrity": "sha512-7vwq+rOHVWjyXxVlR76Agnvhy8I9rpzjosTESvmhNeXOXdZZB15Fl+TI9x1SiHZH5Jv2wTGduSxFDIaq0m3DUw==", 40 | "dependencies": { 41 | "@hapi/hoek": "^9.0.0" 42 | } 43 | }, 44 | "node_modules/@sideway/formula": { 45 | "version": "3.0.1", 46 | "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.1.tgz", 47 | "integrity": "sha512-/poHZJJVjx3L+zVD6g9KgHfYnb443oi7wLu/XKojDviHy6HOEOA6z1Trk5aR1dGcmPenJEgb2sK2I80LeS3MIg==" 48 | }, 49 | "node_modules/@sideway/pinpoint": { 50 | "version": "2.0.0", 51 | "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", 52 | "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==" 53 | }, 54 | "node_modules/@types/debug": { 55 | "version": "4.1.8", 56 | "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.8.tgz", 57 | "integrity": "sha512-/vPO1EPOs306Cvhwv7KfVfYvOJqA/S/AXjaHQiJboCZzcNDb+TIJFN9/2C9DZ//ijSKWioNyUxD792QmDJ+HKQ==", 58 | "dependencies": { 59 | "@types/ms": "*" 60 | } 61 | }, 62 | "node_modules/@types/ms": { 63 | "version": "0.7.31", 64 | "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", 65 | "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==" 66 | }, 67 | "node_modules/@types/node": { 68 | "version": "20.4.5", 69 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.4.5.tgz", 70 | "integrity": "sha512-rt40Nk13II9JwQBdeYqmbn2Q6IVTA5uPhvSO+JVqdXw/6/4glI6oR9ezty/A9Hg5u7JH4OmYmuQ+XvjKm0Datg==" 71 | }, 72 | "node_modules/@types/uuid": { 73 | "version": "8.3.4", 74 | "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-8.3.4.tgz", 75 | "integrity": "sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw==" 76 | }, 77 | "node_modules/@types/validator": { 78 | "version": "13.7.17", 79 | "resolved": "https://registry.npmjs.org/@types/validator/-/validator-13.7.17.tgz", 80 | "integrity": "sha512-aqayTNmeWrZcvnG2MG9eGYI6b7S5fl+yKgPs6bAjOTwPS316R5SxBGKvtSExfyoJU7pIeHJfsHI0Ji41RVMkvQ==" 81 | }, 82 | "node_modules/abbrev": { 83 | "version": "1.1.1", 84 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 85 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 86 | }, 87 | "node_modules/accepts": { 88 | "version": "1.3.8", 89 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 90 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 91 | "dependencies": { 92 | "mime-types": "~2.1.34", 93 | "negotiator": "0.6.3" 94 | }, 95 | "engines": { 96 | "node": ">= 0.6" 97 | } 98 | }, 99 | "node_modules/ansi-regex": { 100 | "version": "5.0.1", 101 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 102 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 103 | "engines": { 104 | "node": ">=8" 105 | } 106 | }, 107 | "node_modules/ansi-styles": { 108 | "version": "4.3.0", 109 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 110 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 111 | "dependencies": { 112 | "color-convert": "^2.0.1" 113 | }, 114 | "engines": { 115 | "node": ">=8" 116 | }, 117 | "funding": { 118 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 119 | } 120 | }, 121 | "node_modules/anymatch": { 122 | "version": "3.1.3", 123 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 124 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 125 | "dependencies": { 126 | "normalize-path": "^3.0.0", 127 | "picomatch": "^2.0.4" 128 | }, 129 | "engines": { 130 | "node": ">= 8" 131 | } 132 | }, 133 | "node_modules/array-flatten": { 134 | "version": "1.1.1", 135 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 136 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 137 | }, 138 | "node_modules/at-least-node": { 139 | "version": "1.0.0", 140 | "resolved": "https://registry.npmjs.org/at-least-node/-/at-least-node-1.0.0.tgz", 141 | "integrity": "sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg==", 142 | "engines": { 143 | "node": ">= 4.0.0" 144 | } 145 | }, 146 | "node_modules/balanced-match": { 147 | "version": "1.0.2", 148 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 149 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 150 | }, 151 | "node_modules/binary-extensions": { 152 | "version": "2.2.0", 153 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 154 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 155 | "engines": { 156 | "node": ">=8" 157 | } 158 | }, 159 | "node_modules/bluebird": { 160 | "version": "3.7.2", 161 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 162 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" 163 | }, 164 | "node_modules/body-parser": { 165 | "version": "1.20.1", 166 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 167 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 168 | "dependencies": { 169 | "bytes": "3.1.2", 170 | "content-type": "~1.0.4", 171 | "debug": "2.6.9", 172 | "depd": "2.0.0", 173 | "destroy": "1.2.0", 174 | "http-errors": "2.0.0", 175 | "iconv-lite": "0.4.24", 176 | "on-finished": "2.4.1", 177 | "qs": "6.11.0", 178 | "raw-body": "2.5.1", 179 | "type-is": "~1.6.18", 180 | "unpipe": "1.0.0" 181 | }, 182 | "engines": { 183 | "node": ">= 0.8", 184 | "npm": "1.2.8000 || >= 1.4.16" 185 | } 186 | }, 187 | "node_modules/body-parser/node_modules/debug": { 188 | "version": "2.6.9", 189 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 190 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 191 | "dependencies": { 192 | "ms": "2.0.0" 193 | } 194 | }, 195 | "node_modules/body-parser/node_modules/ms": { 196 | "version": "2.0.0", 197 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 198 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 199 | }, 200 | "node_modules/brace-expansion": { 201 | "version": "2.0.1", 202 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 203 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 204 | "dependencies": { 205 | "balanced-match": "^1.0.0" 206 | } 207 | }, 208 | "node_modules/braces": { 209 | "version": "3.0.2", 210 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 211 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 212 | "dependencies": { 213 | "fill-range": "^7.0.1" 214 | }, 215 | "engines": { 216 | "node": ">=8" 217 | } 218 | }, 219 | "node_modules/buffer-writer": { 220 | "version": "2.0.0", 221 | "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz", 222 | "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw==", 223 | "engines": { 224 | "node": ">=4" 225 | } 226 | }, 227 | "node_modules/bytes": { 228 | "version": "3.1.2", 229 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 230 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 231 | "engines": { 232 | "node": ">= 0.8" 233 | } 234 | }, 235 | "node_modules/call-bind": { 236 | "version": "1.0.2", 237 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 238 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 239 | "dependencies": { 240 | "function-bind": "^1.1.1", 241 | "get-intrinsic": "^1.0.2" 242 | }, 243 | "funding": { 244 | "url": "https://github.com/sponsors/ljharb" 245 | } 246 | }, 247 | "node_modules/chokidar": { 248 | "version": "3.5.3", 249 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 250 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 251 | "funding": [ 252 | { 253 | "type": "individual", 254 | "url": "https://paulmillr.com/funding/" 255 | } 256 | ], 257 | "dependencies": { 258 | "anymatch": "~3.1.2", 259 | "braces": "~3.0.2", 260 | "glob-parent": "~5.1.2", 261 | "is-binary-path": "~2.1.0", 262 | "is-glob": "~4.0.1", 263 | "normalize-path": "~3.0.0", 264 | "readdirp": "~3.6.0" 265 | }, 266 | "engines": { 267 | "node": ">= 8.10.0" 268 | }, 269 | "optionalDependencies": { 270 | "fsevents": "~2.3.2" 271 | } 272 | }, 273 | "node_modules/cli-color": { 274 | "version": "2.0.3", 275 | "resolved": "https://registry.npmjs.org/cli-color/-/cli-color-2.0.3.tgz", 276 | "integrity": "sha512-OkoZnxyC4ERN3zLzZaY9Emb7f/MhBOIpePv0Ycok0fJYT+Ouo00UBEIwsVsr0yoow++n5YWlSUgST9GKhNHiRQ==", 277 | "dependencies": { 278 | "d": "^1.0.1", 279 | "es5-ext": "^0.10.61", 280 | "es6-iterator": "^2.0.3", 281 | "memoizee": "^0.4.15", 282 | "timers-ext": "^0.1.7" 283 | }, 284 | "engines": { 285 | "node": ">=0.10" 286 | } 287 | }, 288 | "node_modules/cliui": { 289 | "version": "7.0.4", 290 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 291 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 292 | "dependencies": { 293 | "string-width": "^4.2.0", 294 | "strip-ansi": "^6.0.0", 295 | "wrap-ansi": "^7.0.0" 296 | } 297 | }, 298 | "node_modules/color-convert": { 299 | "version": "2.0.1", 300 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 301 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 302 | "dependencies": { 303 | "color-name": "~1.1.4" 304 | }, 305 | "engines": { 306 | "node": ">=7.0.0" 307 | } 308 | }, 309 | "node_modules/color-name": { 310 | "version": "1.1.4", 311 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 312 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 313 | }, 314 | "node_modules/commander": { 315 | "version": "10.0.1", 316 | "resolved": "https://registry.npmjs.org/commander/-/commander-10.0.1.tgz", 317 | "integrity": "sha512-y4Mg2tXshplEbSGzx7amzPwKKOCGuoSRP/CjEdwwk0FOGlUbq6lKuoyDZTNZkmxHdJtp54hdfY/JUrdL7Xfdug==", 318 | "engines": { 319 | "node": ">=14" 320 | } 321 | }, 322 | "node_modules/concat-map": { 323 | "version": "0.0.1", 324 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 325 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" 326 | }, 327 | "node_modules/config-chain": { 328 | "version": "1.1.13", 329 | "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.13.tgz", 330 | "integrity": "sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==", 331 | "dependencies": { 332 | "ini": "^1.3.4", 333 | "proto-list": "~1.2.1" 334 | } 335 | }, 336 | "node_modules/content-disposition": { 337 | "version": "0.5.4", 338 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 339 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 340 | "dependencies": { 341 | "safe-buffer": "5.2.1" 342 | }, 343 | "engines": { 344 | "node": ">= 0.6" 345 | } 346 | }, 347 | "node_modules/content-type": { 348 | "version": "1.0.5", 349 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 350 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 351 | "engines": { 352 | "node": ">= 0.6" 353 | } 354 | }, 355 | "node_modules/cookie": { 356 | "version": "0.5.0", 357 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 358 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 359 | "engines": { 360 | "node": ">= 0.6" 361 | } 362 | }, 363 | "node_modules/cookie-signature": { 364 | "version": "1.0.6", 365 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 366 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 367 | }, 368 | "node_modules/d": { 369 | "version": "1.0.1", 370 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", 371 | "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", 372 | "dependencies": { 373 | "es5-ext": "^0.10.50", 374 | "type": "^1.0.1" 375 | } 376 | }, 377 | "node_modules/debug": { 378 | "version": "4.3.4", 379 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 380 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 381 | "dependencies": { 382 | "ms": "2.1.2" 383 | }, 384 | "engines": { 385 | "node": ">=6.0" 386 | }, 387 | "peerDependenciesMeta": { 388 | "supports-color": { 389 | "optional": true 390 | } 391 | } 392 | }, 393 | "node_modules/depd": { 394 | "version": "2.0.0", 395 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 396 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 397 | "engines": { 398 | "node": ">= 0.8" 399 | } 400 | }, 401 | "node_modules/destroy": { 402 | "version": "1.2.0", 403 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 404 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 405 | "engines": { 406 | "node": ">= 0.8", 407 | "npm": "1.2.8000 || >= 1.4.16" 408 | } 409 | }, 410 | "node_modules/dottie": { 411 | "version": "2.0.6", 412 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.6.tgz", 413 | "integrity": "sha512-iGCHkfUc5kFekGiqhe8B/mdaurD+lakO9txNnTvKtA6PISrw86LgqHvRzWYPyoE2Ph5aMIrCw9/uko6XHTKCwA==" 414 | }, 415 | "node_modules/editorconfig": { 416 | "version": "1.0.4", 417 | "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-1.0.4.tgz", 418 | "integrity": "sha512-L9Qe08KWTlqYMVvMcTIvMAdl1cDUubzRNYL+WfA4bLDMHe4nemKkpmYzkznE1FwLKu0EEmy6obgQKzMJrg4x9Q==", 419 | "dependencies": { 420 | "@one-ini/wasm": "0.1.1", 421 | "commander": "^10.0.0", 422 | "minimatch": "9.0.1", 423 | "semver": "^7.5.3" 424 | }, 425 | "bin": { 426 | "editorconfig": "bin/editorconfig" 427 | }, 428 | "engines": { 429 | "node": ">=14" 430 | } 431 | }, 432 | "node_modules/ee-first": { 433 | "version": "1.1.1", 434 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 435 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 436 | }, 437 | "node_modules/emoji-regex": { 438 | "version": "8.0.0", 439 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 440 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 441 | }, 442 | "node_modules/encodeurl": { 443 | "version": "1.0.2", 444 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 445 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 446 | "engines": { 447 | "node": ">= 0.8" 448 | } 449 | }, 450 | "node_modules/es5-ext": { 451 | "version": "0.10.62", 452 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.62.tgz", 453 | "integrity": "sha512-BHLqn0klhEpnOKSrzn/Xsz2UIW8j+cGmo9JLzr8BiUapV8hPL9+FliFqjwr9ngW7jWdnxv6eO+/LqyhJVqgrjA==", 454 | "hasInstallScript": true, 455 | "dependencies": { 456 | "es6-iterator": "^2.0.3", 457 | "es6-symbol": "^3.1.3", 458 | "next-tick": "^1.1.0" 459 | }, 460 | "engines": { 461 | "node": ">=0.10" 462 | } 463 | }, 464 | "node_modules/es6-iterator": { 465 | "version": "2.0.3", 466 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 467 | "integrity": "sha512-zw4SRzoUkd+cl+ZoE15A9o1oQd920Bb0iOJMQkQhl3jNc03YqVjAhG7scf9C5KWRU/R13Orf588uCC6525o02g==", 468 | "dependencies": { 469 | "d": "1", 470 | "es5-ext": "^0.10.35", 471 | "es6-symbol": "^3.1.1" 472 | } 473 | }, 474 | "node_modules/es6-symbol": { 475 | "version": "3.1.3", 476 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", 477 | "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", 478 | "dependencies": { 479 | "d": "^1.0.1", 480 | "ext": "^1.1.2" 481 | } 482 | }, 483 | "node_modules/es6-weak-map": { 484 | "version": "2.0.3", 485 | "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.3.tgz", 486 | "integrity": "sha512-p5um32HOTO1kP+w7PRnB+5lQ43Z6muuMuIMffvDN8ZB4GcnjLBV6zGStpbASIMk4DCAvEaamhe2zhyCb/QXXsA==", 487 | "dependencies": { 488 | "d": "1", 489 | "es5-ext": "^0.10.46", 490 | "es6-iterator": "^2.0.3", 491 | "es6-symbol": "^3.1.1" 492 | } 493 | }, 494 | "node_modules/escalade": { 495 | "version": "3.1.1", 496 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 497 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 498 | "engines": { 499 | "node": ">=6" 500 | } 501 | }, 502 | "node_modules/escape-html": { 503 | "version": "1.0.3", 504 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 505 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 506 | }, 507 | "node_modules/etag": { 508 | "version": "1.8.1", 509 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 510 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 511 | "engines": { 512 | "node": ">= 0.6" 513 | } 514 | }, 515 | "node_modules/event-emitter": { 516 | "version": "0.3.5", 517 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 518 | "integrity": "sha512-D9rRn9y7kLPnJ+hMq7S/nhvoKwwvVJahBi2BPmx3bvbsEdK3W9ii8cBSGjP+72/LnM4n6fo3+dkCX5FeTQruXA==", 519 | "dependencies": { 520 | "d": "1", 521 | "es5-ext": "~0.10.14" 522 | } 523 | }, 524 | "node_modules/express": { 525 | "version": "4.18.2", 526 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 527 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 528 | "dependencies": { 529 | "accepts": "~1.3.8", 530 | "array-flatten": "1.1.1", 531 | "body-parser": "1.20.1", 532 | "content-disposition": "0.5.4", 533 | "content-type": "~1.0.4", 534 | "cookie": "0.5.0", 535 | "cookie-signature": "1.0.6", 536 | "debug": "2.6.9", 537 | "depd": "2.0.0", 538 | "encodeurl": "~1.0.2", 539 | "escape-html": "~1.0.3", 540 | "etag": "~1.8.1", 541 | "finalhandler": "1.2.0", 542 | "fresh": "0.5.2", 543 | "http-errors": "2.0.0", 544 | "merge-descriptors": "1.0.1", 545 | "methods": "~1.1.2", 546 | "on-finished": "2.4.1", 547 | "parseurl": "~1.3.3", 548 | "path-to-regexp": "0.1.7", 549 | "proxy-addr": "~2.0.7", 550 | "qs": "6.11.0", 551 | "range-parser": "~1.2.1", 552 | "safe-buffer": "5.2.1", 553 | "send": "0.18.0", 554 | "serve-static": "1.15.0", 555 | "setprototypeof": "1.2.0", 556 | "statuses": "2.0.1", 557 | "type-is": "~1.6.18", 558 | "utils-merge": "1.0.1", 559 | "vary": "~1.1.2" 560 | }, 561 | "engines": { 562 | "node": ">= 0.10.0" 563 | } 564 | }, 565 | "node_modules/express/node_modules/debug": { 566 | "version": "2.6.9", 567 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 568 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 569 | "dependencies": { 570 | "ms": "2.0.0" 571 | } 572 | }, 573 | "node_modules/express/node_modules/ms": { 574 | "version": "2.0.0", 575 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 576 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 577 | }, 578 | "node_modules/ext": { 579 | "version": "1.7.0", 580 | "resolved": "https://registry.npmjs.org/ext/-/ext-1.7.0.tgz", 581 | "integrity": "sha512-6hxeJYaL110a9b5TEJSj0gojyHQAmA2ch5Os+ySCiA1QGdS697XWY1pzsrSjqA9LDEEgdB/KypIlR59RcLuHYw==", 582 | "dependencies": { 583 | "type": "^2.7.2" 584 | } 585 | }, 586 | "node_modules/ext/node_modules/type": { 587 | "version": "2.7.2", 588 | "resolved": "https://registry.npmjs.org/type/-/type-2.7.2.tgz", 589 | "integrity": "sha512-dzlvlNlt6AXU7EBSfpAscydQ7gXB+pPGsPnfJnZpiNJBDj7IaJzQlBZYGdEi4R9HmPdBv2XmWJ6YUtoTa7lmCw==" 590 | }, 591 | "node_modules/fill-range": { 592 | "version": "7.0.1", 593 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 594 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 595 | "dependencies": { 596 | "to-regex-range": "^5.0.1" 597 | }, 598 | "engines": { 599 | "node": ">=8" 600 | } 601 | }, 602 | "node_modules/finalhandler": { 603 | "version": "1.2.0", 604 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 605 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 606 | "dependencies": { 607 | "debug": "2.6.9", 608 | "encodeurl": "~1.0.2", 609 | "escape-html": "~1.0.3", 610 | "on-finished": "2.4.1", 611 | "parseurl": "~1.3.3", 612 | "statuses": "2.0.1", 613 | "unpipe": "~1.0.0" 614 | }, 615 | "engines": { 616 | "node": ">= 0.8" 617 | } 618 | }, 619 | "node_modules/finalhandler/node_modules/debug": { 620 | "version": "2.6.9", 621 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 622 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 623 | "dependencies": { 624 | "ms": "2.0.0" 625 | } 626 | }, 627 | "node_modules/finalhandler/node_modules/ms": { 628 | "version": "2.0.0", 629 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 630 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 631 | }, 632 | "node_modules/forwarded": { 633 | "version": "0.2.0", 634 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 635 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 636 | "engines": { 637 | "node": ">= 0.6" 638 | } 639 | }, 640 | "node_modules/fresh": { 641 | "version": "0.5.2", 642 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 643 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 644 | "engines": { 645 | "node": ">= 0.6" 646 | } 647 | }, 648 | "node_modules/fs-extra": { 649 | "version": "9.1.0", 650 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", 651 | "integrity": "sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==", 652 | "dependencies": { 653 | "at-least-node": "^1.0.0", 654 | "graceful-fs": "^4.2.0", 655 | "jsonfile": "^6.0.1", 656 | "universalify": "^2.0.0" 657 | }, 658 | "engines": { 659 | "node": ">=10" 660 | } 661 | }, 662 | "node_modules/fs.realpath": { 663 | "version": "1.0.0", 664 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 665 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" 666 | }, 667 | "node_modules/fsevents": { 668 | "version": "2.3.2", 669 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 670 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 671 | "hasInstallScript": true, 672 | "optional": true, 673 | "os": [ 674 | "darwin" 675 | ], 676 | "engines": { 677 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 678 | } 679 | }, 680 | "node_modules/function-bind": { 681 | "version": "1.1.1", 682 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 683 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 684 | }, 685 | "node_modules/get-caller-file": { 686 | "version": "2.0.5", 687 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 688 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 689 | "engines": { 690 | "node": "6.* || 8.* || >= 10.*" 691 | } 692 | }, 693 | "node_modules/get-intrinsic": { 694 | "version": "1.2.1", 695 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 696 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 697 | "dependencies": { 698 | "function-bind": "^1.1.1", 699 | "has": "^1.0.3", 700 | "has-proto": "^1.0.1", 701 | "has-symbols": "^1.0.3" 702 | }, 703 | "funding": { 704 | "url": "https://github.com/sponsors/ljharb" 705 | } 706 | }, 707 | "node_modules/glob": { 708 | "version": "8.1.0", 709 | "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", 710 | "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==", 711 | "dependencies": { 712 | "fs.realpath": "^1.0.0", 713 | "inflight": "^1.0.4", 714 | "inherits": "2", 715 | "minimatch": "^5.0.1", 716 | "once": "^1.3.0" 717 | }, 718 | "engines": { 719 | "node": ">=12" 720 | }, 721 | "funding": { 722 | "url": "https://github.com/sponsors/isaacs" 723 | } 724 | }, 725 | "node_modules/glob-parent": { 726 | "version": "5.1.2", 727 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 728 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 729 | "dependencies": { 730 | "is-glob": "^4.0.1" 731 | }, 732 | "engines": { 733 | "node": ">= 6" 734 | } 735 | }, 736 | "node_modules/glob/node_modules/minimatch": { 737 | "version": "5.1.6", 738 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 739 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 740 | "dependencies": { 741 | "brace-expansion": "^2.0.1" 742 | }, 743 | "engines": { 744 | "node": ">=10" 745 | } 746 | }, 747 | "node_modules/graceful-fs": { 748 | "version": "4.2.11", 749 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 750 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 751 | }, 752 | "node_modules/has": { 753 | "version": "1.0.3", 754 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 755 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 756 | "dependencies": { 757 | "function-bind": "^1.1.1" 758 | }, 759 | "engines": { 760 | "node": ">= 0.4.0" 761 | } 762 | }, 763 | "node_modules/has-flag": { 764 | "version": "3.0.0", 765 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 766 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 767 | "engines": { 768 | "node": ">=4" 769 | } 770 | }, 771 | "node_modules/has-proto": { 772 | "version": "1.0.1", 773 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 774 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", 775 | "engines": { 776 | "node": ">= 0.4" 777 | }, 778 | "funding": { 779 | "url": "https://github.com/sponsors/ljharb" 780 | } 781 | }, 782 | "node_modules/has-symbols": { 783 | "version": "1.0.3", 784 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 785 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 786 | "engines": { 787 | "node": ">= 0.4" 788 | }, 789 | "funding": { 790 | "url": "https://github.com/sponsors/ljharb" 791 | } 792 | }, 793 | "node_modules/http-errors": { 794 | "version": "2.0.0", 795 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 796 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 797 | "dependencies": { 798 | "depd": "2.0.0", 799 | "inherits": "2.0.4", 800 | "setprototypeof": "1.2.0", 801 | "statuses": "2.0.1", 802 | "toidentifier": "1.0.1" 803 | }, 804 | "engines": { 805 | "node": ">= 0.8" 806 | } 807 | }, 808 | "node_modules/iconv-lite": { 809 | "version": "0.4.24", 810 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 811 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 812 | "dependencies": { 813 | "safer-buffer": ">= 2.1.2 < 3" 814 | }, 815 | "engines": { 816 | "node": ">=0.10.0" 817 | } 818 | }, 819 | "node_modules/ignore-by-default": { 820 | "version": "1.0.1", 821 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 822 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==" 823 | }, 824 | "node_modules/inflection": { 825 | "version": "1.13.4", 826 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.4.tgz", 827 | "integrity": "sha512-6I/HUDeYFfuNCVS3td055BaXBwKYuzw7K3ExVMStBowKo9oOAMJIXIHvdyR3iboTCp1b+1i5DSkIZTcwIktuDw==", 828 | "engines": [ 829 | "node >= 0.4.0" 830 | ] 831 | }, 832 | "node_modules/inflight": { 833 | "version": "1.0.6", 834 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 835 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 836 | "dependencies": { 837 | "once": "^1.3.0", 838 | "wrappy": "1" 839 | } 840 | }, 841 | "node_modules/inherits": { 842 | "version": "2.0.4", 843 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 844 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 845 | }, 846 | "node_modules/ini": { 847 | "version": "1.3.8", 848 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 849 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" 850 | }, 851 | "node_modules/ipaddr.js": { 852 | "version": "1.9.1", 853 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 854 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 855 | "engines": { 856 | "node": ">= 0.10" 857 | } 858 | }, 859 | "node_modules/is-binary-path": { 860 | "version": "2.1.0", 861 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 862 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 863 | "dependencies": { 864 | "binary-extensions": "^2.0.0" 865 | }, 866 | "engines": { 867 | "node": ">=8" 868 | } 869 | }, 870 | "node_modules/is-core-module": { 871 | "version": "2.12.1", 872 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", 873 | "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", 874 | "dependencies": { 875 | "has": "^1.0.3" 876 | }, 877 | "funding": { 878 | "url": "https://github.com/sponsors/ljharb" 879 | } 880 | }, 881 | "node_modules/is-extglob": { 882 | "version": "2.1.1", 883 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 884 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 885 | "engines": { 886 | "node": ">=0.10.0" 887 | } 888 | }, 889 | "node_modules/is-fullwidth-code-point": { 890 | "version": "3.0.0", 891 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 892 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 893 | "engines": { 894 | "node": ">=8" 895 | } 896 | }, 897 | "node_modules/is-glob": { 898 | "version": "4.0.3", 899 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 900 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 901 | "dependencies": { 902 | "is-extglob": "^2.1.1" 903 | }, 904 | "engines": { 905 | "node": ">=0.10.0" 906 | } 907 | }, 908 | "node_modules/is-number": { 909 | "version": "7.0.0", 910 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 911 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 912 | "engines": { 913 | "node": ">=0.12.0" 914 | } 915 | }, 916 | "node_modules/is-promise": { 917 | "version": "2.2.2", 918 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.2.2.tgz", 919 | "integrity": "sha512-+lP4/6lKUBfQjZ2pdxThZvLUAafmZb8OAxFb8XXtiQmS35INgr85hdOGoEs124ez1FCnZJt6jau/T+alh58QFQ==" 920 | }, 921 | "node_modules/joi": { 922 | "version": "17.9.2", 923 | "resolved": "https://registry.npmjs.org/joi/-/joi-17.9.2.tgz", 924 | "integrity": "sha512-Itk/r+V4Dx0V3c7RLFdRh12IOjySm2/WGPMubBT92cQvRfYZhPM2W0hZlctjj72iES8jsRCwp7S/cRmWBnJ4nw==", 925 | "dependencies": { 926 | "@hapi/hoek": "^9.0.0", 927 | "@hapi/topo": "^5.0.0", 928 | "@sideway/address": "^4.1.3", 929 | "@sideway/formula": "^3.0.1", 930 | "@sideway/pinpoint": "^2.0.0" 931 | } 932 | }, 933 | "node_modules/js-beautify": { 934 | "version": "1.14.9", 935 | "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.9.tgz", 936 | "integrity": "sha512-coM7xq1syLcMyuVGyToxcj2AlzhkDjmfklL8r0JgJ7A76wyGMpJ1oA35mr4APdYNO/o/4YY8H54NQIJzhMbhBg==", 937 | "dependencies": { 938 | "config-chain": "^1.1.13", 939 | "editorconfig": "^1.0.3", 940 | "glob": "^8.1.0", 941 | "nopt": "^6.0.0" 942 | }, 943 | "bin": { 944 | "css-beautify": "js/bin/css-beautify.js", 945 | "html-beautify": "js/bin/html-beautify.js", 946 | "js-beautify": "js/bin/js-beautify.js" 947 | }, 948 | "engines": { 949 | "node": ">=12" 950 | } 951 | }, 952 | "node_modules/jsonfile": { 953 | "version": "6.1.0", 954 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", 955 | "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", 956 | "dependencies": { 957 | "universalify": "^2.0.0" 958 | }, 959 | "optionalDependencies": { 960 | "graceful-fs": "^4.1.6" 961 | } 962 | }, 963 | "node_modules/lodash": { 964 | "version": "4.17.21", 965 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 966 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 967 | }, 968 | "node_modules/lru-cache": { 969 | "version": "6.0.0", 970 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 971 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 972 | "dependencies": { 973 | "yallist": "^4.0.0" 974 | }, 975 | "engines": { 976 | "node": ">=10" 977 | } 978 | }, 979 | "node_modules/lru-queue": { 980 | "version": "0.1.0", 981 | "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", 982 | "integrity": "sha512-BpdYkt9EvGl8OfWHDQPISVpcl5xZthb+XPsbELj5AQXxIC8IriDZIQYjBJPEm5rS420sjZ0TLEzRcq5KdBhYrQ==", 983 | "dependencies": { 984 | "es5-ext": "~0.10.2" 985 | } 986 | }, 987 | "node_modules/media-typer": { 988 | "version": "0.3.0", 989 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 990 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 991 | "engines": { 992 | "node": ">= 0.6" 993 | } 994 | }, 995 | "node_modules/memoizee": { 996 | "version": "0.4.15", 997 | "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.15.tgz", 998 | "integrity": "sha512-UBWmJpLZd5STPm7PMUlOw/TSy972M+z8gcyQ5veOnSDRREz/0bmpyTfKt3/51DhEBqCZQn1udM/5flcSPYhkdQ==", 999 | "dependencies": { 1000 | "d": "^1.0.1", 1001 | "es5-ext": "^0.10.53", 1002 | "es6-weak-map": "^2.0.3", 1003 | "event-emitter": "^0.3.5", 1004 | "is-promise": "^2.2.2", 1005 | "lru-queue": "^0.1.0", 1006 | "next-tick": "^1.1.0", 1007 | "timers-ext": "^0.1.7" 1008 | } 1009 | }, 1010 | "node_modules/merge-descriptors": { 1011 | "version": "1.0.1", 1012 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1013 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 1014 | }, 1015 | "node_modules/methods": { 1016 | "version": "1.1.2", 1017 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1018 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 1019 | "engines": { 1020 | "node": ">= 0.6" 1021 | } 1022 | }, 1023 | "node_modules/mime": { 1024 | "version": "1.6.0", 1025 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1026 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1027 | "bin": { 1028 | "mime": "cli.js" 1029 | }, 1030 | "engines": { 1031 | "node": ">=4" 1032 | } 1033 | }, 1034 | "node_modules/mime-db": { 1035 | "version": "1.52.0", 1036 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1037 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1038 | "engines": { 1039 | "node": ">= 0.6" 1040 | } 1041 | }, 1042 | "node_modules/mime-types": { 1043 | "version": "2.1.35", 1044 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1045 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1046 | "dependencies": { 1047 | "mime-db": "1.52.0" 1048 | }, 1049 | "engines": { 1050 | "node": ">= 0.6" 1051 | } 1052 | }, 1053 | "node_modules/minimatch": { 1054 | "version": "9.0.1", 1055 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.1.tgz", 1056 | "integrity": "sha512-0jWhJpD/MdhPXwPuiRkCbfYfSKp2qnn2eOc279qI7f+osl/l+prKSrvhg157zSYvx/1nmgn2NqdT6k2Z7zSH9w==", 1057 | "dependencies": { 1058 | "brace-expansion": "^2.0.1" 1059 | }, 1060 | "engines": { 1061 | "node": ">=16 || 14 >=14.17" 1062 | }, 1063 | "funding": { 1064 | "url": "https://github.com/sponsors/isaacs" 1065 | } 1066 | }, 1067 | "node_modules/moment": { 1068 | "version": "2.29.4", 1069 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 1070 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 1071 | "engines": { 1072 | "node": "*" 1073 | } 1074 | }, 1075 | "node_modules/moment-timezone": { 1076 | "version": "0.5.43", 1077 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.43.tgz", 1078 | "integrity": "sha512-72j3aNyuIsDxdF1i7CEgV2FfxM1r6aaqJyLB2vwb33mXYyoyLly+F1zbWqhA3/bVIoJ4szlUoMbUnVdid32NUQ==", 1079 | "dependencies": { 1080 | "moment": "^2.29.4" 1081 | }, 1082 | "engines": { 1083 | "node": "*" 1084 | } 1085 | }, 1086 | "node_modules/ms": { 1087 | "version": "2.1.2", 1088 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1089 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1090 | }, 1091 | "node_modules/negotiator": { 1092 | "version": "0.6.3", 1093 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1094 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1095 | "engines": { 1096 | "node": ">= 0.6" 1097 | } 1098 | }, 1099 | "node_modules/next-tick": { 1100 | "version": "1.1.0", 1101 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.1.0.tgz", 1102 | "integrity": "sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ==" 1103 | }, 1104 | "node_modules/nodemon": { 1105 | "version": "3.0.1", 1106 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.0.1.tgz", 1107 | "integrity": "sha512-g9AZ7HmkhQkqXkRc20w+ZfQ73cHLbE8hnPbtaFbFtCumZsjyMhKk9LajQ07U5Ux28lvFjZ5X7HvWR1xzU8jHVw==", 1108 | "dependencies": { 1109 | "chokidar": "^3.5.2", 1110 | "debug": "^3.2.7", 1111 | "ignore-by-default": "^1.0.1", 1112 | "minimatch": "^3.1.2", 1113 | "pstree.remy": "^1.1.8", 1114 | "semver": "^7.5.3", 1115 | "simple-update-notifier": "^2.0.0", 1116 | "supports-color": "^5.5.0", 1117 | "touch": "^3.1.0", 1118 | "undefsafe": "^2.0.5" 1119 | }, 1120 | "bin": { 1121 | "nodemon": "bin/nodemon.js" 1122 | }, 1123 | "engines": { 1124 | "node": ">=10" 1125 | }, 1126 | "funding": { 1127 | "type": "opencollective", 1128 | "url": "https://opencollective.com/nodemon" 1129 | } 1130 | }, 1131 | "node_modules/nodemon/node_modules/brace-expansion": { 1132 | "version": "1.1.11", 1133 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1134 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1135 | "dependencies": { 1136 | "balanced-match": "^1.0.0", 1137 | "concat-map": "0.0.1" 1138 | } 1139 | }, 1140 | "node_modules/nodemon/node_modules/debug": { 1141 | "version": "3.2.7", 1142 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1143 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1144 | "dependencies": { 1145 | "ms": "^2.1.1" 1146 | } 1147 | }, 1148 | "node_modules/nodemon/node_modules/minimatch": { 1149 | "version": "3.1.2", 1150 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1151 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1152 | "dependencies": { 1153 | "brace-expansion": "^1.1.7" 1154 | }, 1155 | "engines": { 1156 | "node": "*" 1157 | } 1158 | }, 1159 | "node_modules/nopt": { 1160 | "version": "6.0.0", 1161 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-6.0.0.tgz", 1162 | "integrity": "sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g==", 1163 | "dependencies": { 1164 | "abbrev": "^1.0.0" 1165 | }, 1166 | "bin": { 1167 | "nopt": "bin/nopt.js" 1168 | }, 1169 | "engines": { 1170 | "node": "^12.13.0 || ^14.15.0 || >=16.0.0" 1171 | } 1172 | }, 1173 | "node_modules/normalize-path": { 1174 | "version": "3.0.0", 1175 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1176 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1177 | "engines": { 1178 | "node": ">=0.10.0" 1179 | } 1180 | }, 1181 | "node_modules/object-inspect": { 1182 | "version": "1.12.3", 1183 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 1184 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 1185 | "funding": { 1186 | "url": "https://github.com/sponsors/ljharb" 1187 | } 1188 | }, 1189 | "node_modules/on-finished": { 1190 | "version": "2.4.1", 1191 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1192 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1193 | "dependencies": { 1194 | "ee-first": "1.1.1" 1195 | }, 1196 | "engines": { 1197 | "node": ">= 0.8" 1198 | } 1199 | }, 1200 | "node_modules/once": { 1201 | "version": "1.4.0", 1202 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1203 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1204 | "dependencies": { 1205 | "wrappy": "1" 1206 | } 1207 | }, 1208 | "node_modules/packet-reader": { 1209 | "version": "1.0.0", 1210 | "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz", 1211 | "integrity": "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ==" 1212 | }, 1213 | "node_modules/parseurl": { 1214 | "version": "1.3.3", 1215 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1216 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1217 | "engines": { 1218 | "node": ">= 0.8" 1219 | } 1220 | }, 1221 | "node_modules/path-parse": { 1222 | "version": "1.0.7", 1223 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1224 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" 1225 | }, 1226 | "node_modules/path-to-regexp": { 1227 | "version": "0.1.7", 1228 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1229 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 1230 | }, 1231 | "node_modules/pg": { 1232 | "version": "8.11.1", 1233 | "resolved": "https://registry.npmjs.org/pg/-/pg-8.11.1.tgz", 1234 | "integrity": "sha512-utdq2obft07MxaDg0zBJI+l/M3mBRfIpEN3iSemsz0G5F2/VXx+XzqF4oxrbIZXQxt2AZzIUzyVg/YM6xOP/WQ==", 1235 | "dependencies": { 1236 | "buffer-writer": "2.0.0", 1237 | "packet-reader": "1.0.0", 1238 | "pg-connection-string": "^2.6.1", 1239 | "pg-pool": "^3.6.1", 1240 | "pg-protocol": "^1.6.0", 1241 | "pg-types": "^2.1.0", 1242 | "pgpass": "1.x" 1243 | }, 1244 | "engines": { 1245 | "node": ">= 8.0.0" 1246 | }, 1247 | "optionalDependencies": { 1248 | "pg-cloudflare": "^1.1.1" 1249 | }, 1250 | "peerDependencies": { 1251 | "pg-native": ">=3.0.1" 1252 | }, 1253 | "peerDependenciesMeta": { 1254 | "pg-native": { 1255 | "optional": true 1256 | } 1257 | } 1258 | }, 1259 | "node_modules/pg-cloudflare": { 1260 | "version": "1.1.1", 1261 | "resolved": "https://registry.npmjs.org/pg-cloudflare/-/pg-cloudflare-1.1.1.tgz", 1262 | "integrity": "sha512-xWPagP/4B6BgFO+EKz3JONXv3YDgvkbVrGw2mTo3D6tVDQRh1e7cqVGvyR3BE+eQgAvx1XhW/iEASj4/jCWl3Q==", 1263 | "optional": true 1264 | }, 1265 | "node_modules/pg-connection-string": { 1266 | "version": "2.6.1", 1267 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.6.1.tgz", 1268 | "integrity": "sha512-w6ZzNu6oMmIzEAYVw+RLK0+nqHPt8K3ZnknKi+g48Ak2pr3dtljJW3o+D/n2zzCG07Zoe9VOX3aiKpj+BN0pjg==" 1269 | }, 1270 | "node_modules/pg-hstore": { 1271 | "version": "2.3.4", 1272 | "resolved": "https://registry.npmjs.org/pg-hstore/-/pg-hstore-2.3.4.tgz", 1273 | "integrity": "sha512-N3SGs/Rf+xA1M2/n0JBiXFDVMzdekwLZLAO0g7mpDY9ouX+fDI7jS6kTq3JujmYbtNSJ53TJ0q4G98KVZSM4EA==", 1274 | "dependencies": { 1275 | "underscore": "^1.13.1" 1276 | }, 1277 | "engines": { 1278 | "node": ">= 0.8.x" 1279 | } 1280 | }, 1281 | "node_modules/pg-int8": { 1282 | "version": "1.0.1", 1283 | "resolved": "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz", 1284 | "integrity": "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw==", 1285 | "engines": { 1286 | "node": ">=4.0.0" 1287 | } 1288 | }, 1289 | "node_modules/pg-pool": { 1290 | "version": "3.6.1", 1291 | "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-3.6.1.tgz", 1292 | "integrity": "sha512-jizsIzhkIitxCGfPRzJn1ZdcosIt3pz9Sh3V01fm1vZnbnCMgmGl5wvGGdNN2EL9Rmb0EcFoCkixH4Pu+sP9Og==", 1293 | "peerDependencies": { 1294 | "pg": ">=8.0" 1295 | } 1296 | }, 1297 | "node_modules/pg-protocol": { 1298 | "version": "1.6.0", 1299 | "resolved": "https://registry.npmjs.org/pg-protocol/-/pg-protocol-1.6.0.tgz", 1300 | "integrity": "sha512-M+PDm637OY5WM307051+bsDia5Xej6d9IR4GwJse1qA1DIhiKlksvrneZOYQq42OM+spubpcNYEo2FcKQrDk+Q==" 1301 | }, 1302 | "node_modules/pg-types": { 1303 | "version": "2.2.0", 1304 | "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-2.2.0.tgz", 1305 | "integrity": "sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA==", 1306 | "dependencies": { 1307 | "pg-int8": "1.0.1", 1308 | "postgres-array": "~2.0.0", 1309 | "postgres-bytea": "~1.0.0", 1310 | "postgres-date": "~1.0.4", 1311 | "postgres-interval": "^1.1.0" 1312 | }, 1313 | "engines": { 1314 | "node": ">=4" 1315 | } 1316 | }, 1317 | "node_modules/pgpass": { 1318 | "version": "1.0.5", 1319 | "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.5.tgz", 1320 | "integrity": "sha512-FdW9r/jQZhSeohs1Z3sI1yxFQNFvMcnmfuj4WBMUTxOrAyLMaTcE1aAMBiTlbMNaXvBCQuVi0R7hd8udDSP7ug==", 1321 | "dependencies": { 1322 | "split2": "^4.1.0" 1323 | } 1324 | }, 1325 | "node_modules/picomatch": { 1326 | "version": "2.3.1", 1327 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1328 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1329 | "engines": { 1330 | "node": ">=8.6" 1331 | }, 1332 | "funding": { 1333 | "url": "https://github.com/sponsors/jonschlinkert" 1334 | } 1335 | }, 1336 | "node_modules/postgres-array": { 1337 | "version": "2.0.0", 1338 | "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz", 1339 | "integrity": "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA==", 1340 | "engines": { 1341 | "node": ">=4" 1342 | } 1343 | }, 1344 | "node_modules/postgres-bytea": { 1345 | "version": "1.0.0", 1346 | "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz", 1347 | "integrity": "sha512-xy3pmLuQqRBZBXDULy7KbaitYqLcmxigw14Q5sj8QBVLqEwXfeybIKVWiqAXTlcvdvb0+xkOtDbfQMOf4lST1w==", 1348 | "engines": { 1349 | "node": ">=0.10.0" 1350 | } 1351 | }, 1352 | "node_modules/postgres-date": { 1353 | "version": "1.0.7", 1354 | "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.7.tgz", 1355 | "integrity": "sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q==", 1356 | "engines": { 1357 | "node": ">=0.10.0" 1358 | } 1359 | }, 1360 | "node_modules/postgres-interval": { 1361 | "version": "1.2.0", 1362 | "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz", 1363 | "integrity": "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==", 1364 | "dependencies": { 1365 | "xtend": "^4.0.0" 1366 | }, 1367 | "engines": { 1368 | "node": ">=0.10.0" 1369 | } 1370 | }, 1371 | "node_modules/proto-list": { 1372 | "version": "1.2.4", 1373 | "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", 1374 | "integrity": "sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==" 1375 | }, 1376 | "node_modules/proxy-addr": { 1377 | "version": "2.0.7", 1378 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1379 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1380 | "dependencies": { 1381 | "forwarded": "0.2.0", 1382 | "ipaddr.js": "1.9.1" 1383 | }, 1384 | "engines": { 1385 | "node": ">= 0.10" 1386 | } 1387 | }, 1388 | "node_modules/pstree.remy": { 1389 | "version": "1.1.8", 1390 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1391 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 1392 | }, 1393 | "node_modules/qs": { 1394 | "version": "6.11.0", 1395 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1396 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1397 | "dependencies": { 1398 | "side-channel": "^1.0.4" 1399 | }, 1400 | "engines": { 1401 | "node": ">=0.6" 1402 | }, 1403 | "funding": { 1404 | "url": "https://github.com/sponsors/ljharb" 1405 | } 1406 | }, 1407 | "node_modules/range-parser": { 1408 | "version": "1.2.1", 1409 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1410 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1411 | "engines": { 1412 | "node": ">= 0.6" 1413 | } 1414 | }, 1415 | "node_modules/raw-body": { 1416 | "version": "2.5.1", 1417 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 1418 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 1419 | "dependencies": { 1420 | "bytes": "3.1.2", 1421 | "http-errors": "2.0.0", 1422 | "iconv-lite": "0.4.24", 1423 | "unpipe": "1.0.0" 1424 | }, 1425 | "engines": { 1426 | "node": ">= 0.8" 1427 | } 1428 | }, 1429 | "node_modules/readdirp": { 1430 | "version": "3.6.0", 1431 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1432 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1433 | "dependencies": { 1434 | "picomatch": "^2.2.1" 1435 | }, 1436 | "engines": { 1437 | "node": ">=8.10.0" 1438 | } 1439 | }, 1440 | "node_modules/require-directory": { 1441 | "version": "2.1.1", 1442 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1443 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1444 | "engines": { 1445 | "node": ">=0.10.0" 1446 | } 1447 | }, 1448 | "node_modules/resolve": { 1449 | "version": "1.22.2", 1450 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", 1451 | "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", 1452 | "dependencies": { 1453 | "is-core-module": "^2.11.0", 1454 | "path-parse": "^1.0.7", 1455 | "supports-preserve-symlinks-flag": "^1.0.0" 1456 | }, 1457 | "bin": { 1458 | "resolve": "bin/resolve" 1459 | }, 1460 | "funding": { 1461 | "url": "https://github.com/sponsors/ljharb" 1462 | } 1463 | }, 1464 | "node_modules/retry-as-promised": { 1465 | "version": "7.0.4", 1466 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-7.0.4.tgz", 1467 | "integrity": "sha512-XgmCoxKWkDofwH8WddD0w85ZfqYz+ZHlr5yo+3YUCfycWawU56T5ckWXsScsj5B8tqUcIG67DxXByo3VUgiAdA==" 1468 | }, 1469 | "node_modules/safe-buffer": { 1470 | "version": "5.2.1", 1471 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1472 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1473 | "funding": [ 1474 | { 1475 | "type": "github", 1476 | "url": "https://github.com/sponsors/feross" 1477 | }, 1478 | { 1479 | "type": "patreon", 1480 | "url": "https://www.patreon.com/feross" 1481 | }, 1482 | { 1483 | "type": "consulting", 1484 | "url": "https://feross.org/support" 1485 | } 1486 | ] 1487 | }, 1488 | "node_modules/safer-buffer": { 1489 | "version": "2.1.2", 1490 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1491 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1492 | }, 1493 | "node_modules/semver": { 1494 | "version": "7.5.4", 1495 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 1496 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 1497 | "dependencies": { 1498 | "lru-cache": "^6.0.0" 1499 | }, 1500 | "bin": { 1501 | "semver": "bin/semver.js" 1502 | }, 1503 | "engines": { 1504 | "node": ">=10" 1505 | } 1506 | }, 1507 | "node_modules/send": { 1508 | "version": "0.18.0", 1509 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1510 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1511 | "dependencies": { 1512 | "debug": "2.6.9", 1513 | "depd": "2.0.0", 1514 | "destroy": "1.2.0", 1515 | "encodeurl": "~1.0.2", 1516 | "escape-html": "~1.0.3", 1517 | "etag": "~1.8.1", 1518 | "fresh": "0.5.2", 1519 | "http-errors": "2.0.0", 1520 | "mime": "1.6.0", 1521 | "ms": "2.1.3", 1522 | "on-finished": "2.4.1", 1523 | "range-parser": "~1.2.1", 1524 | "statuses": "2.0.1" 1525 | }, 1526 | "engines": { 1527 | "node": ">= 0.8.0" 1528 | } 1529 | }, 1530 | "node_modules/send/node_modules/debug": { 1531 | "version": "2.6.9", 1532 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1533 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1534 | "dependencies": { 1535 | "ms": "2.0.0" 1536 | } 1537 | }, 1538 | "node_modules/send/node_modules/debug/node_modules/ms": { 1539 | "version": "2.0.0", 1540 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1541 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1542 | }, 1543 | "node_modules/send/node_modules/ms": { 1544 | "version": "2.1.3", 1545 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1546 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1547 | }, 1548 | "node_modules/sequelize": { 1549 | "version": "6.32.1", 1550 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.32.1.tgz", 1551 | "integrity": "sha512-3Iv0jruv57Y0YvcxQW7BE56O7DC1BojcfIrqh6my+IQwde+9u/YnuYHzK+8kmZLhLvaziRT1eWu38nh9yVwn/g==", 1552 | "funding": [ 1553 | { 1554 | "type": "opencollective", 1555 | "url": "https://opencollective.com/sequelize" 1556 | } 1557 | ], 1558 | "dependencies": { 1559 | "@types/debug": "^4.1.8", 1560 | "@types/validator": "^13.7.17", 1561 | "debug": "^4.3.4", 1562 | "dottie": "^2.0.4", 1563 | "inflection": "^1.13.4", 1564 | "lodash": "^4.17.21", 1565 | "moment": "^2.29.4", 1566 | "moment-timezone": "^0.5.43", 1567 | "pg-connection-string": "^2.6.0", 1568 | "retry-as-promised": "^7.0.4", 1569 | "semver": "^7.5.1", 1570 | "sequelize-pool": "^7.1.0", 1571 | "toposort-class": "^1.0.1", 1572 | "uuid": "^8.3.2", 1573 | "validator": "^13.9.0", 1574 | "wkx": "^0.5.0" 1575 | }, 1576 | "engines": { 1577 | "node": ">=10.0.0" 1578 | }, 1579 | "peerDependenciesMeta": { 1580 | "ibm_db": { 1581 | "optional": true 1582 | }, 1583 | "mariadb": { 1584 | "optional": true 1585 | }, 1586 | "mysql2": { 1587 | "optional": true 1588 | }, 1589 | "oracledb": { 1590 | "optional": true 1591 | }, 1592 | "pg": { 1593 | "optional": true 1594 | }, 1595 | "pg-hstore": { 1596 | "optional": true 1597 | }, 1598 | "snowflake-sdk": { 1599 | "optional": true 1600 | }, 1601 | "sqlite3": { 1602 | "optional": true 1603 | }, 1604 | "tedious": { 1605 | "optional": true 1606 | } 1607 | } 1608 | }, 1609 | "node_modules/sequelize-cli": { 1610 | "version": "6.6.1", 1611 | "resolved": "https://registry.npmjs.org/sequelize-cli/-/sequelize-cli-6.6.1.tgz", 1612 | "integrity": "sha512-C3qRpy1twBsFa855qOQFSYWer8ngiaZP05/OAsT1QCUwtc6UxVNNiQ0CGUt98T9T1gi5D3TGWL6le8HWUKELyw==", 1613 | "dependencies": { 1614 | "cli-color": "^2.0.3", 1615 | "fs-extra": "^9.1.0", 1616 | "js-beautify": "^1.14.5", 1617 | "lodash": "^4.17.21", 1618 | "resolve": "^1.22.1", 1619 | "umzug": "^2.3.0", 1620 | "yargs": "^16.2.0" 1621 | }, 1622 | "bin": { 1623 | "sequelize": "lib/sequelize", 1624 | "sequelize-cli": "lib/sequelize" 1625 | }, 1626 | "engines": { 1627 | "node": ">=10.0.0" 1628 | } 1629 | }, 1630 | "node_modules/sequelize-pool": { 1631 | "version": "7.1.0", 1632 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-7.1.0.tgz", 1633 | "integrity": "sha512-G9c0qlIWQSK29pR/5U2JF5dDQeqqHRragoyahj/Nx4KOOQ3CPPfzxnfqFPCSB7x5UgjOgnZ61nSxz+fjDpRlJg==", 1634 | "engines": { 1635 | "node": ">= 10.0.0" 1636 | } 1637 | }, 1638 | "node_modules/serve-static": { 1639 | "version": "1.15.0", 1640 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1641 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1642 | "dependencies": { 1643 | "encodeurl": "~1.0.2", 1644 | "escape-html": "~1.0.3", 1645 | "parseurl": "~1.3.3", 1646 | "send": "0.18.0" 1647 | }, 1648 | "engines": { 1649 | "node": ">= 0.8.0" 1650 | } 1651 | }, 1652 | "node_modules/setprototypeof": { 1653 | "version": "1.2.0", 1654 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1655 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1656 | }, 1657 | "node_modules/side-channel": { 1658 | "version": "1.0.4", 1659 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1660 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1661 | "dependencies": { 1662 | "call-bind": "^1.0.0", 1663 | "get-intrinsic": "^1.0.2", 1664 | "object-inspect": "^1.9.0" 1665 | }, 1666 | "funding": { 1667 | "url": "https://github.com/sponsors/ljharb" 1668 | } 1669 | }, 1670 | "node_modules/simple-update-notifier": { 1671 | "version": "2.0.0", 1672 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", 1673 | "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", 1674 | "dependencies": { 1675 | "semver": "^7.5.3" 1676 | }, 1677 | "engines": { 1678 | "node": ">=10" 1679 | } 1680 | }, 1681 | "node_modules/split2": { 1682 | "version": "4.2.0", 1683 | "resolved": "https://registry.npmjs.org/split2/-/split2-4.2.0.tgz", 1684 | "integrity": "sha512-UcjcJOWknrNkF6PLX83qcHM6KHgVKNkV62Y8a5uYDVv9ydGQVwAHMKqHdJje1VTWpljG0WYpCDhrCdAOYH4TWg==", 1685 | "engines": { 1686 | "node": ">= 10.x" 1687 | } 1688 | }, 1689 | "node_modules/statuses": { 1690 | "version": "2.0.1", 1691 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1692 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1693 | "engines": { 1694 | "node": ">= 0.8" 1695 | } 1696 | }, 1697 | "node_modules/string-width": { 1698 | "version": "4.2.3", 1699 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1700 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1701 | "dependencies": { 1702 | "emoji-regex": "^8.0.0", 1703 | "is-fullwidth-code-point": "^3.0.0", 1704 | "strip-ansi": "^6.0.1" 1705 | }, 1706 | "engines": { 1707 | "node": ">=8" 1708 | } 1709 | }, 1710 | "node_modules/strip-ansi": { 1711 | "version": "6.0.1", 1712 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1713 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1714 | "dependencies": { 1715 | "ansi-regex": "^5.0.1" 1716 | }, 1717 | "engines": { 1718 | "node": ">=8" 1719 | } 1720 | }, 1721 | "node_modules/supports-color": { 1722 | "version": "5.5.0", 1723 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1724 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1725 | "dependencies": { 1726 | "has-flag": "^3.0.0" 1727 | }, 1728 | "engines": { 1729 | "node": ">=4" 1730 | } 1731 | }, 1732 | "node_modules/supports-preserve-symlinks-flag": { 1733 | "version": "1.0.0", 1734 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1735 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1736 | "engines": { 1737 | "node": ">= 0.4" 1738 | }, 1739 | "funding": { 1740 | "url": "https://github.com/sponsors/ljharb" 1741 | } 1742 | }, 1743 | "node_modules/timers-ext": { 1744 | "version": "0.1.7", 1745 | "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.7.tgz", 1746 | "integrity": "sha512-b85NUNzTSdodShTIbky6ZF02e8STtVVfD+fu4aXXShEELpozH+bCpJLYMPZbsABN2wDH7fJpqIoXxJpzbf0NqQ==", 1747 | "dependencies": { 1748 | "es5-ext": "~0.10.46", 1749 | "next-tick": "1" 1750 | } 1751 | }, 1752 | "node_modules/to-regex-range": { 1753 | "version": "5.0.1", 1754 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1755 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1756 | "dependencies": { 1757 | "is-number": "^7.0.0" 1758 | }, 1759 | "engines": { 1760 | "node": ">=8.0" 1761 | } 1762 | }, 1763 | "node_modules/toidentifier": { 1764 | "version": "1.0.1", 1765 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1766 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1767 | "engines": { 1768 | "node": ">=0.6" 1769 | } 1770 | }, 1771 | "node_modules/toposort-class": { 1772 | "version": "1.0.1", 1773 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 1774 | "integrity": "sha512-OsLcGGbYF3rMjPUf8oKktyvCiUxSbqMMS39m33MAjLTC1DVIH6x3WSt63/M77ihI09+Sdfk1AXvfhCEeUmC7mg==" 1775 | }, 1776 | "node_modules/touch": { 1777 | "version": "3.1.0", 1778 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1779 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1780 | "dependencies": { 1781 | "nopt": "~1.0.10" 1782 | }, 1783 | "bin": { 1784 | "nodetouch": "bin/nodetouch.js" 1785 | } 1786 | }, 1787 | "node_modules/touch/node_modules/nopt": { 1788 | "version": "1.0.10", 1789 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1790 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 1791 | "dependencies": { 1792 | "abbrev": "1" 1793 | }, 1794 | "bin": { 1795 | "nopt": "bin/nopt.js" 1796 | }, 1797 | "engines": { 1798 | "node": "*" 1799 | } 1800 | }, 1801 | "node_modules/type": { 1802 | "version": "1.2.0", 1803 | "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", 1804 | "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==" 1805 | }, 1806 | "node_modules/type-is": { 1807 | "version": "1.6.18", 1808 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1809 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1810 | "dependencies": { 1811 | "media-typer": "0.3.0", 1812 | "mime-types": "~2.1.24" 1813 | }, 1814 | "engines": { 1815 | "node": ">= 0.6" 1816 | } 1817 | }, 1818 | "node_modules/umzug": { 1819 | "version": "2.3.0", 1820 | "resolved": "https://registry.npmjs.org/umzug/-/umzug-2.3.0.tgz", 1821 | "integrity": "sha512-Z274K+e8goZK8QJxmbRPhl89HPO1K+ORFtm6rySPhFKfKc5GHhqdzD0SGhSWHkzoXasqJuItdhorSvY7/Cgflw==", 1822 | "dependencies": { 1823 | "bluebird": "^3.7.2" 1824 | }, 1825 | "engines": { 1826 | "node": ">=6.0.0" 1827 | } 1828 | }, 1829 | "node_modules/undefsafe": { 1830 | "version": "2.0.5", 1831 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1832 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==" 1833 | }, 1834 | "node_modules/underscore": { 1835 | "version": "1.13.6", 1836 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz", 1837 | "integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==" 1838 | }, 1839 | "node_modules/universalify": { 1840 | "version": "2.0.0", 1841 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.0.tgz", 1842 | "integrity": "sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==", 1843 | "engines": { 1844 | "node": ">= 10.0.0" 1845 | } 1846 | }, 1847 | "node_modules/unpipe": { 1848 | "version": "1.0.0", 1849 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1850 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1851 | "engines": { 1852 | "node": ">= 0.8" 1853 | } 1854 | }, 1855 | "node_modules/utils-merge": { 1856 | "version": "1.0.1", 1857 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1858 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1859 | "engines": { 1860 | "node": ">= 0.4.0" 1861 | } 1862 | }, 1863 | "node_modules/uuid": { 1864 | "version": "8.3.2", 1865 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 1866 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 1867 | "bin": { 1868 | "uuid": "dist/bin/uuid" 1869 | } 1870 | }, 1871 | "node_modules/uuidv4": { 1872 | "version": "6.2.13", 1873 | "resolved": "https://registry.npmjs.org/uuidv4/-/uuidv4-6.2.13.tgz", 1874 | "integrity": "sha512-AXyzMjazYB3ovL3q051VLH06Ixj//Knx7QnUSi1T//Ie3io6CpsPu9nVMOx5MoLWh6xV0B9J0hIaxungxXUbPQ==", 1875 | "dependencies": { 1876 | "@types/uuid": "8.3.4", 1877 | "uuid": "8.3.2" 1878 | } 1879 | }, 1880 | "node_modules/validator": { 1881 | "version": "13.9.0", 1882 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.9.0.tgz", 1883 | "integrity": "sha512-B+dGG8U3fdtM0/aNK4/X8CXq/EcxU2WPrPEkJGslb47qyHsxmbggTWK0yEA4qnYVNF+nxNlN88o14hIcPmSIEA==", 1884 | "engines": { 1885 | "node": ">= 0.10" 1886 | } 1887 | }, 1888 | "node_modules/vary": { 1889 | "version": "1.1.2", 1890 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1891 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1892 | "engines": { 1893 | "node": ">= 0.8" 1894 | } 1895 | }, 1896 | "node_modules/wkx": { 1897 | "version": "0.5.0", 1898 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz", 1899 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==", 1900 | "dependencies": { 1901 | "@types/node": "*" 1902 | } 1903 | }, 1904 | "node_modules/wrap-ansi": { 1905 | "version": "7.0.0", 1906 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1907 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1908 | "dependencies": { 1909 | "ansi-styles": "^4.0.0", 1910 | "string-width": "^4.1.0", 1911 | "strip-ansi": "^6.0.0" 1912 | }, 1913 | "engines": { 1914 | "node": ">=10" 1915 | }, 1916 | "funding": { 1917 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1918 | } 1919 | }, 1920 | "node_modules/wrappy": { 1921 | "version": "1.0.2", 1922 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1923 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 1924 | }, 1925 | "node_modules/xtend": { 1926 | "version": "4.0.2", 1927 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 1928 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 1929 | "engines": { 1930 | "node": ">=0.4" 1931 | } 1932 | }, 1933 | "node_modules/y18n": { 1934 | "version": "5.0.8", 1935 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1936 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1937 | "engines": { 1938 | "node": ">=10" 1939 | } 1940 | }, 1941 | "node_modules/yallist": { 1942 | "version": "4.0.0", 1943 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1944 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1945 | }, 1946 | "node_modules/yargs": { 1947 | "version": "16.2.0", 1948 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1949 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1950 | "dependencies": { 1951 | "cliui": "^7.0.2", 1952 | "escalade": "^3.1.1", 1953 | "get-caller-file": "^2.0.5", 1954 | "require-directory": "^2.1.1", 1955 | "string-width": "^4.2.0", 1956 | "y18n": "^5.0.5", 1957 | "yargs-parser": "^20.2.2" 1958 | }, 1959 | "engines": { 1960 | "node": ">=10" 1961 | } 1962 | }, 1963 | "node_modules/yargs-parser": { 1964 | "version": "20.2.9", 1965 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 1966 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 1967 | "engines": { 1968 | "node": ">=10" 1969 | } 1970 | } 1971 | } 1972 | } 1973 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "dependencies": { 3 | "express": "^4.18.2", 4 | "joi": "^17.9.2", 5 | "nodemon": "^3.0.1", 6 | "pg": "^8.11.1", 7 | "pg-hstore": "^2.3.4", 8 | "sequelize": "^6.32.1", 9 | "sequelize-cli": "^6.6.1", 10 | "uuidv4": "^6.2.13" 11 | }, 12 | "name": "seque", 13 | "version": "1.0.0", 14 | "main": "query.js", 15 | "devDependencies": {}, 16 | "scripts": { 17 | "start": "nodemon server.js", 18 | "test": "echo \"Error: no test specified\" && exit 1" 19 | }, 20 | "repository": { 21 | "type": "git", 22 | "url": "git+https://github.com/001-mak/Sequelize-Postgres-Database.git" 23 | }, 24 | "keywords": [], 25 | "author": "", 26 | "license": "ISC", 27 | "bugs": { 28 | "url": "https://github.com/001-mak/Sequelize-Postgres-Database/issues" 29 | }, 30 | "homepage": "https://github.com/001-mak/Sequelize-Postgres-Database#readme", 31 | "description": "" 32 | } 33 | -------------------------------------------------------------------------------- /query.js: -------------------------------------------------------------------------------- 1 | const db = require('./models/index'); 2 | 3 | 4 | // Find all users 5 | const query = async () =>{ 6 | 7 | //get all projects 8 | 9 | const projects = await db.User.findAll({ 10 | attributes:['firstName', 'id'] 11 | }); 12 | console.log("All projects:", JSON.stringify(projects, null, 2)); 13 | 14 | //get all users 15 | 16 | // const user = await db.User.findOne(); 17 | // console.log("All users:", JSON.stringify(user, null, 2)); 18 | 19 | //create user 20 | // const user = await db.User.create({ 21 | // id: 7, 22 | // firstName: "Alex", 23 | // lastName: "Vee", 24 | // departmentId: 2, 25 | // projectId: 4, 26 | // createdAt: new Date(), 27 | // updatedAt: new Date(), 28 | // }) 29 | // console.log("All users:", JSON.stringify(user, null, 2)); 30 | 31 | //update user 32 | // const user = await db.User.update({ firstName: 'Jay'}, 33 | // { 34 | // where: { 35 | // id:7 36 | // } 37 | // } 38 | // ); 39 | // const user =await db.User.findOne({where:{id:7}}) 40 | // console.log(user); 41 | 42 | 43 | 44 | //create department 45 | // const department = await db.Department.create({ 46 | // id: 5, 47 | // departmentName: "QA", 48 | // phone: "813-456-5230", 49 | // createdAt: new Date(), 50 | // updatedAt: new Date(), 51 | // }) 52 | 53 | 54 | //create user 55 | 56 | // const user = await db.User.create({ 57 | // id: 6, 58 | // firstName: "Alex", 59 | // lastName: "Zee", 60 | // departmentId: 5, 61 | // projectId: 1, 62 | // createdAt: new Date(), 63 | // updatedAt: new Date(), 64 | // }) 65 | // console.log("New User Added:", JSON.stringify(user, null, 2)); 66 | 67 | 68 | } 69 | 70 | query(); 71 | -------------------------------------------------------------------------------- /repositories/departmentRepo.js: -------------------------------------------------------------------------------- 1 | const db = require("../models/index"); 2 | 3 | const getDepartmentsRepo = async () => { 4 | try { 5 | const departments = await db.Department.findAll({ 6 | attributes: ["id", "departmentName", "phone"], 7 | }); 8 | return departments; 9 | } catch (error) { 10 | console.log(error); 11 | } 12 | }; 13 | 14 | const getDepartmentRepo = async (reqId) => { 15 | try { 16 | const department = await db.Department.findOne({ 17 | attributes: ["id", "departmentName", "phone"], 18 | where: { 19 | id: reqId, 20 | }, 21 | }); 22 | return department; 23 | } catch (error) { 24 | console.log(error); 25 | } 26 | }; 27 | 28 | const createDepartmentRepo = async (departmentObj) => { 29 | try { 30 | const department = await db.Department.create({ 31 | id:departmentObj.id, 32 | departmentName : departmentObj.departmentName, 33 | phone: departmentObj.phone, 34 | createdAt: departmentObj.createdAt, 35 | updatedAt: departmentObj.updatedAt, 36 | }); 37 | return department; 38 | } catch (error) { 39 | console.log(error); 40 | } 41 | }; 42 | 43 | const deleteDepartmentRepo = async (reqId) => { 44 | try { 45 | const department = await db.Department.destroy({ 46 | where: { 47 | id: reqId, 48 | }, 49 | }); 50 | return department; 51 | } catch (error) { 52 | console.log(error); 53 | } 54 | }; 55 | const updateDepartmentRepo = async (reqId,updatedObj) => { 56 | try { 57 | const department = await db.Department.update(updatedObj,{ 58 | where: { 59 | id: reqId, 60 | }, 61 | }); 62 | return department; 63 | } catch (error) { 64 | console.log(error); 65 | } 66 | }; 67 | 68 | module.exports = { 69 | getDepartmentsRepo, 70 | getDepartmentRepo, 71 | createDepartmentRepo, 72 | deleteDepartmentRepo, 73 | updateDepartmentRepo, 74 | }; 75 | -------------------------------------------------------------------------------- /repositories/userRepo.js: -------------------------------------------------------------------------------- 1 | const db = require('../models/index'); 2 | 3 | 4 | const getUsersRepo = async()=>{ 5 | try { 6 | const users = await db.User.findAll({ 7 | attributes: ['id', 'firstName', 'lastName', 'departmentId', 'projectId'] 8 | }) 9 | return users 10 | } catch (error) { 11 | console.log(error) 12 | } 13 | } 14 | 15 | const getUserRepo = async(userId)=>{ 16 | try { 17 | const user = await db.User.findAll({ 18 | where:{ 19 | id : userId 20 | } 21 | }) 22 | return user 23 | } catch (error) { 24 | console.log(error) 25 | } 26 | } 27 | 28 | module.exports = { getUsersRepo, getUserRepo } -------------------------------------------------------------------------------- /routes/departmentRoutes.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | 4 | const {getDepartments,createDepartment} = require('../controllers/departmentController') 5 | 6 | 7 | router.get('/departments', getDepartments); 8 | router.post('/create-department', createDepartment); 9 | 10 | module.exports = router; -------------------------------------------------------------------------------- /routes/userRoutes.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | 4 | const {getUsers, createUser, updateUser, deleteUser} = require('../controllers/userController') 5 | 6 | 7 | router.get('/users', getUsers); 8 | router.post('/create-user', createUser); 9 | router.put('/update-user', updateUser); 10 | router.delete('/delete-user', deleteUser); 11 | 12 | module.exports = router; 13 | -------------------------------------------------------------------------------- /schemaValidation/userSchema.js: -------------------------------------------------------------------------------- 1 | const Joi = require('joi'); 2 | 3 | const userSchema = Joi.object({ 4 | id: Joi.number().required(), 5 | firstName: Joi.string().required(), 6 | lastName: Joi.string().required(), 7 | departmentId: Joi.number().required(), 8 | projectId: Joi.number().required(), 9 | }) 10 | 11 | module.exports = {userSchema} -------------------------------------------------------------------------------- /seeders/20230730132300-demo-departments.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | /** @type {import('sequelize-cli').Migration} */ 4 | module.exports = { 5 | up: (queryInterface, Sequelize) => { 6 | return queryInterface.bulkInsert("Departments", [ 7 | { 8 | id: 1, 9 | departmentName: "Human Resources", 10 | phone: "123-456-7890", 11 | createdAt: new Date(), 12 | updatedAt: new Date(), 13 | }, 14 | { 15 | id: 2, 16 | departmentName: "Marketing", 17 | phone: "987-654-3210", 18 | createdAt: new Date(), 19 | updatedAt: new Date(), 20 | }, 21 | { 22 | id: 3, 23 | departmentName: "IT", 24 | phone: "123-456-7223", 25 | createdAt: new Date(), 26 | updatedAt: new Date(), 27 | }, 28 | { 29 | id: 4, 30 | departmentName: "Finance", 31 | phone: "521-456-7890", 32 | createdAt: new Date(), 33 | updatedAt: new Date(), 34 | }, 35 | ]); 36 | }, 37 | down: (queryInterface, Sequelize) => { 38 | return queryInterface.bulkDelete("Departments", null, {}); 39 | }, 40 | }; 41 | -------------------------------------------------------------------------------- /seeders/20230730132902-demo-projects.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | /** @type {import('sequelize-cli').Migration} */ 4 | module.exports = { 5 | up: (queryInterface, Sequelize) => { 6 | return queryInterface.bulkInsert("Projects", [ 7 | { 8 | id: 1, 9 | projectName: "Website Redesign", 10 | createdAt: new Date(), 11 | updatedAt: new Date(), 12 | }, 13 | { 14 | id: 2, 15 | projectName: "Logo Redesign", 16 | createdAt: new Date(), 17 | updatedAt: new Date(), 18 | }, 19 | { 20 | id: 3, 21 | projectName: "label Redesign", 22 | createdAt: new Date(), 23 | updatedAt: new Date(), 24 | }, 25 | { 26 | id: 4, 27 | projectName: "software development", 28 | createdAt: new Date(), 29 | updatedAt: new Date(), 30 | }, 31 | { 32 | id: 5, 33 | projectName: "Marketing", 34 | createdAt: new Date(), 35 | updatedAt: new Date(), 36 | }, 37 | ]); 38 | }, 39 | down: (queryInterface, Sequelize) => { 40 | return queryInterface.bulkDelete("Projects", null, {}); 41 | }, 42 | }; 43 | -------------------------------------------------------------------------------- /seeders/20230730140759-demo-users.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | /** @type {import('sequelize-cli').Migration} */ 4 | module.exports = { 5 | up: (queryInterface, Sequelize) => { 6 | return queryInterface.bulkInsert("Users", [ 7 | { 8 | id: 1, 9 | firstName: "John", 10 | lastName: "Doe", 11 | departmentId: 2, 12 | projectId: 4, 13 | createdAt: new Date(), 14 | updatedAt: new Date(), 15 | }, 16 | { 17 | id: 2, 18 | firstName: "Jane", 19 | lastName: "Smith", 20 | departmentId: 2, 21 | projectId: 4, 22 | createdAt: new Date(), 23 | updatedAt: new Date(), 24 | }, 25 | { 26 | id: 3, 27 | firstName: "Michael", 28 | lastName: "Johnson", 29 | departmentId: 2, 30 | projectId: 4, 31 | createdAt: new Date(), 32 | updatedAt: new Date(), 33 | }, 34 | { 35 | id: 4, 36 | firstName: "Emily", 37 | lastName: "Williams", 38 | departmentId: 2, 39 | projectId: 4, 40 | createdAt: new Date(), 41 | updatedAt: new Date(), 42 | }, 43 | { 44 | id: 5, 45 | firstName: "David", 46 | lastName: "Brown", 47 | departmentId: 2, 48 | projectId: 4, 49 | createdAt: new Date(), 50 | updatedAt: new Date(), 51 | }, 52 | ]); 53 | }, 54 | down: (queryInterface, Sequelize) => { 55 | return queryInterface.bulkDelete("Users", null, {}); 56 | }, 57 | }; 58 | -------------------------------------------------------------------------------- /server.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const app = express(); 3 | 4 | app.use(express.json()); 5 | 6 | app.use('/api', require('./routes/userRoutes')) 7 | app.use('/api', require('./routes/departmentRoutes')) 8 | app.listen('5000', ()=>{ 9 | console.log("Server running at port 5000") 10 | }) --------------------------------------------------------------------------------