mirror of
https://github.com/20kaushik02/express-sequelize-backend-template.git
synced 2025-12-06 09:34:07 +00:00
overall: formatting check, jsdoc type hints, express res/return stuff utils - changes in logger, dateformatter and removed unneeded ones .env file changes license check, readme update package.json update - version, deps, URLs server cleanup sequelize config check
50 lines
1.2 KiB
JavaScript
50 lines
1.2 KiB
JavaScript
"use strict";
|
|
const fs = require("fs");
|
|
const path = require("path");
|
|
const Sequelize = require("sequelize");
|
|
const logger = require("../utils/logger")(module);
|
|
const basename = path.basename(__filename);
|
|
const env = process.env.NODE_ENV || "development";
|
|
const config = require(__dirname + "/../config/sequelize.js")[env];
|
|
const db = {};
|
|
|
|
let sequelize;
|
|
if (config.use_env_variable) {
|
|
sequelize = new Sequelize(process.env[config.use_env_variable], config);
|
|
} else {
|
|
sequelize = new Sequelize(config.database, config.username, config.password, config);
|
|
}
|
|
|
|
(async () => {
|
|
try {
|
|
await sequelize.authenticate();
|
|
logger.info("Sequelize auth success");
|
|
} catch (error) {
|
|
logger.error("Sequelize auth error", { err });
|
|
throw error;
|
|
}
|
|
})();
|
|
|
|
// Read model definitions from folder
|
|
fs
|
|
.readdirSync(__dirname)
|
|
.filter(file => {
|
|
return (file.indexOf(".") !== 0) && (file !== basename) && (file.slice(-3) === ".js");
|
|
})
|
|
.forEach(file => {
|
|
const model = require(path.join(__dirname, file))(sequelize, Sequelize.DataTypes);
|
|
db[model.name] = model;
|
|
});
|
|
|
|
// Setup defined associations
|
|
Object.keys(db).forEach(modelName => {
|
|
if (db[modelName].associate) {
|
|
db[modelName].associate(db);
|
|
}
|
|
});
|
|
|
|
db.sequelize = sequelize;
|
|
db.Sequelize = Sequelize;
|
|
|
|
module.exports = db;
|