Skip to content

Instantly share code, notes, and snippets.

@Prakhar896
Created May 9, 2024 13:43
Show Gist options
  • Save Prakhar896/8ee150c8e10b52d60fd4af77539ec259 to your computer and use it in GitHub Desktop.
Save Prakhar896/8ee150c8e10b52d60fd4af77539ec259 to your computer and use it in GitHub Desktop.
Initialise a sequelize MySQL database with .env variables. Refer to specific variable names in the code when writing out .env file.
'use strict';
const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const process = require('process');
const basename = path.basename(__filename);
const db = {};
require('dotenv').config();
// Create sequelize instance using config
let sequelize = new Sequelize(
process.env.DB_NAME, process.env.DB_USER, process.env.DB_PWD,
{
host: process.env.DB_HOST,
port: process.env.DB_PORT,
dialect: 'mysql',
logging: false,
timezone: '+08:00'
}
);
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;
});
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment