mirror of
https://github.com/20kaushik02/spotify-manager.git
synced 2026-01-25 06:04:05 +00:00
CJS -> ESM
This commit is contained in:
@@ -1,11 +1,16 @@
|
||||
"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);
|
||||
import { readdirSync } from "fs";
|
||||
import { basename as _basename } from "path";
|
||||
const basename = _basename(import.meta.filename);
|
||||
|
||||
import Sequelize from "sequelize";
|
||||
|
||||
import curriedLogger from "../utils/logger.js";
|
||||
const logger = curriedLogger(import.meta);
|
||||
|
||||
import seqConfig from "../config/sequelize.js"
|
||||
const env = process.env.NODE_ENV || "development";
|
||||
const config = require(__dirname + "/../config/sequelize.js")[env];
|
||||
const config = seqConfig[env];
|
||||
const db = {};
|
||||
|
||||
let sequelize;
|
||||
@@ -26,15 +31,22 @@ if (config.use_env_variable) {
|
||||
})();
|
||||
|
||||
// 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;
|
||||
});
|
||||
const modelFiles = readdirSync(import.meta.dirname)
|
||||
.filter(
|
||||
(file) => file.indexOf('.') !== 0
|
||||
&& file !== basename
|
||||
&& file.slice(-3) === '.js',
|
||||
);
|
||||
|
||||
await Promise.all(modelFiles.map(async file => {
|
||||
const model = await import(`./${file}`);
|
||||
if (!model.default) {
|
||||
return;
|
||||
}
|
||||
|
||||
const namedModel = model.default(sequelize, Sequelize.DataTypes);
|
||||
db[namedModel.name] = namedModel;
|
||||
}))
|
||||
|
||||
// Setup defined associations
|
||||
Object.keys(db).forEach(modelName => {
|
||||
@@ -43,7 +55,9 @@ Object.keys(db).forEach(modelName => {
|
||||
}
|
||||
});
|
||||
|
||||
// clean ts up
|
||||
db.sequelize = sequelize;
|
||||
db.Sequelize = Sequelize;
|
||||
|
||||
module.exports = db;
|
||||
export { sequelize as sequelize };
|
||||
export { Sequelize as Sequelize };
|
||||
export default db;
|
||||
|
||||
@@ -1,8 +1,6 @@
|
||||
"use strict";
|
||||
const {
|
||||
Model
|
||||
} = require("sequelize");
|
||||
module.exports = (sequelize, DataTypes) => {
|
||||
import { Model } from "sequelize";
|
||||
export default (sequelize, DataTypes) => {
|
||||
class links extends Model {
|
||||
/**
|
||||
* Helper method for defining associations.
|
||||
@@ -22,4 +20,4 @@ module.exports = (sequelize, DataTypes) => {
|
||||
modelName: "links",
|
||||
});
|
||||
return links;
|
||||
};
|
||||
};
|
||||
|
||||
@@ -1,8 +1,6 @@
|
||||
"use strict";
|
||||
const {
|
||||
Model
|
||||
} = require("sequelize");
|
||||
module.exports = (sequelize, DataTypes) => {
|
||||
import { Model } from "sequelize";
|
||||
export default (sequelize, DataTypes) => {
|
||||
class playlists extends Model {
|
||||
/**
|
||||
* Helper method for defining associations.
|
||||
@@ -22,4 +20,4 @@ module.exports = (sequelize, DataTypes) => {
|
||||
modelName: "playlists",
|
||||
});
|
||||
return playlists;
|
||||
};
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user