Если бы я сделал ручное соединение с моей базой данных.
Я бы сделал что-то подобное ниже, чтобы обработать ошибку при установлении соединения.
sequelize
.authenticate()
.then(() => {
console.log('Connection has been established successfully.');
})
.catch(err => {
console.error('Unable to connect to the database:', err);
});
Но я использую sequelize-cli. Он сгенерировал файл index.js
, когда я запустил sequelize-init
.
Я хочу отловить ошибку, если она не может подключиться к БД, и отправить в ответ пользовательское сообщение об ошибке.
{
"error" :
{
"status":500,
"message":"Could not connect to database"
}
}
Поэтому я попробовал приведенный ниже код.
'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);
}
//here I tried to test the connection
sequelize
.authenticate()
.then(() => {
console.log('Connection has been established successfully.');
})
.catch(err => {
throw(err)
});
fs
.readdirSync(__dirname)
.filter(file => {
return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
})
.forEach(file => {
const model = sequelize['import'](path.join(__dirname, file));
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;
Выше код не работает.
Как я могу перехватить эту ошибку и отправить сообщение об ошибке, как указано выше?