Skip to content

Instantly share code, notes, and snippets.

@tatsuyasusukida
Created June 28, 2022 23:37
Show Gist options
  • Save tatsuyasusukida/4ab46713fd589886bc26f25e0a7a6504 to your computer and use it in GitHub Desktop.
Save tatsuyasusukida/4ab46713fd589886bc26f25e0a7a6504 to your computer and use it in GitHub Desktop.
πŸš€ How to migrate from CJS to ESM with Sequelize: CJS part
module.exports = function (sequelize, DataTypes) {
const article = sequelize.define('article', {})
article.associate = (models) => {
article.belongsTo(models.user)
}
return article
}
{
"development": {
"username": "tech_blog_user",
"password": "tech_blog_pass",
"database": "tech_blog_db",
"host": "127.0.0.1",
"dialect": "mysql"
},
"test": {
"username": "tech_blog_user",
"password": "tech_blog_pass",
"database": "tech_blog_db",
"host": "127.0.0.1",
"dialect": "mysql"
},
"production": {
"username": "tech_blog_user",
"password": "tech_blog_pass",
"database": "tech_blog_db",
"host": "127.0.0.1",
"dialect": "mysql"
}
}
'use strict';
const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const basename = path.basename(__filename);
const env = process.env.NODE_ENV || 'development';
const config = require(__dirname + '/../config/config.json')[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);
}
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;
const models = require('./models-cjs')
main()
async function main () {
try {
await models.sequelize.sync({force: true})
await models.sequelize.close()
} catch (err) {
console.error(err)
}
}
module.exports = function (sequelize, DataTypes) {
const user = sequelize.define('user', {})
return user
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment