Last active
September 8, 2021 07:22
-
-
Save intech/0618869763b4bf176d53b70b26633408 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// broker.js | |
"use strict"; | |
const { ServiceBroker } = require("moleculer"); | |
const Sequelize = require("./middlewares/sequelize"); | |
const broker = new ServiceBroker({ | |
middlewares: [Sequelize()] | |
}); | |
broker.createService({ | |
name: "service", | |
actions: { | |
action() { | |
return this.models.user.findAll(); | |
} | |
}, | |
}); |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// middlewares/sequelize.js | |
"use strict"; | |
const Sequelize = require("sequelize"); | |
const fs = require("fs"); | |
const path = require("path"); | |
module.exports = function SequelizeDbMiddleware(options = {}) { | |
options = { | |
dialect: "postgres", | |
define: { | |
timestamps: false | |
}, | |
logging: process.env.LOGLEVEL === "debug", | |
pool: { | |
max: 5, | |
min: 0, | |
acquire: 60000, | |
idle: 30000 | |
}, | |
...options | |
}; | |
const connection = new Sequelize(process.env.DATABASE, options); | |
const models = {}; | |
return { | |
name: "Sequelize", | |
created() { | |
this.logger.info("Sequelize middleware ready"); | |
const dir = __dirname + "/../models"; | |
fs | |
.readdirSync(dir) | |
.filter(file => file.endsWith(".js")) | |
.map(file => { | |
const model = require(path.join(dir, file))(connection, Sequelize.DataTypes); | |
models[model.name] = model; | |
return model; | |
}).forEach(model => { | |
if ("associate" in model) model.associate(models); | |
}); | |
this.logger.info("Sequelize all models loaded!"); | |
}, | |
async stopping () { | |
if(connection) await connection.close(); | |
}, | |
serviceCreating(service, schema) { | |
if(!schema.name.startsWith("$")) { | |
service.Sequelize = connection; | |
service.Sequelize.Op = Sequelize.Op; | |
service.models = models; | |
} | |
} | |
}; | |
}; |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// models/user.js | |
"use strict"; | |
module.exports = (sequelize, DataTypes) => { | |
const User = sequelize.define("user", { | |
email: { | |
type: DataTypes.STRING, | |
unique: true | |
}, | |
password: DataTypes.STRING, | |
role: { | |
type: DataTypes.ENUM, | |
values: ["user", "admin"] | |
}, | |
username: { | |
type: DataTypes.STRING, | |
unique: true | |
}, | |
settings: DataTypes.JSONB, | |
status: DataTypes.INTEGER, | |
activation_code: DataTypes.STRING, | |
passwordRecoveryToken: DataTypes.STRING, | |
secret2fa: DataTypes.STRING, | |
referer: DataTypes.UUID, | |
uuid: { | |
type: DataTypes.UUID, | |
primaryKey: true | |
}, | |
registration_date: DataTypes.DATE, | |
last_login_date: DataTypes.DATE | |
}, { | |
}); | |
User.associate = function (models) { | |
User.hasMany(models.worker, {foreignKey: "username", sourceKey: "username"}); | |
}; | |
return User; | |
}; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment