Наконец-то я нашел решение.
configurations.js / PostgreSQL.js:
const Sequelize = require('sequelize');
const sequelize = new Sequelize('database', 'user', 'password', {
host: 'host',
dialect: 'postgres'
});
module.exports = sequelize;
models / users.js:
const sequelize = require('../configurations/PostgreSQL');
const bcrypt = require('bcrypt-nodejs');
const users = sequelize.define('users', {
email: sequelize.Sequelize.STRING,
password: sequelize.Sequelize.STRING,
first_name: sequelize.Sequelize.STRING,
last_name: sequelize.Sequelize.STRING,
active: sequelize.Sequelize.BOOLEAN,
admin: sequelize.Sequelize.BOOLEAN
}, {
timestamps: false,
createdAt: false,
updatedAt: false,
});
users.beforeSave((user) => {
if (user.changed('password')) {
user.password = bcrypt.hashSync(user.password, bcrypt.genSaltSync(10), null);
}
});
users.prototype.comparePassword = function (password, cb) {
bcrypt.compare(password, this.password, function (err, isMatch) {
if (err) {
return cb(err);
}
cb(null, isMatch);
});
};
module.exports = users;
маршруты / пользователи.js:
const express = require('express');
const router = express.Router();
const passport = require('passport');
require('../configurations/password')(passport);
const users = require('../models/users');
router.post('/create', function(req, res) {
if (!req.body.email || !req.body.password) {
res.status(400).send({
status: false,
message: ''
});
} else {
users.create({
email: req.body.email,
password: req.body.password,
first_name: req.body.first_name,
last_name: req.body.last_name,
active: req.body.active,
admin: req.body.admin
}).then((user) => res.status(201).send(user)).catch((error) => {
console.log(error);
res.status(400).send(error);
});
}
});
module.exports = router;