Обрабатывать ошибку соединения в index.js, сгенерированном sequelize-cli - PullRequest
0 голосов
/ 04 октября 2019

Если бы я сделал ручное соединение с моей базой данных.
Я бы сделал что-то подобное ниже, чтобы обработать ошибку при установлении соединения.

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;

Выше код не работает.

Как я могу перехватить эту ошибку и отправить сообщение об ошибке, как указано выше?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...