homepage.js/models/index.js

57 lines
1.3 KiB
JavaScript
Raw Normal View History

2023-02-19 10:54:30 +01:00
'use strict';
2023-02-22 06:39:09 +01:00
require('pg').defaults.parseInt8 = true
2023-02-19 10:54:30 +01:00
const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const process = require('process');
const basename = path.basename(__filename);
2023-02-19 15:19:46 +01:00
const env = process.env.NODE_ENV || 'production';
let config = require(__dirname + '/../config/config.json')[env];
2023-02-22 14:54:35 +01:00
2023-02-19 10:54:30 +01:00
const db = {};
2023-02-19 15:19:46 +01:00
const {
DB_PASSWORD,
DB_USERNAME,
DB_DATABASE,
DB_HOSTNAME
} = process.env;
config = {
...config,
username: DB_USERNAME || config.username,
password: DB_PASSWORD || config.password,
database: DB_DATABASE || config.database,
2023-02-19 16:12:09 +01:00
host: DB_HOSTNAME || config.host,
define: {
timestamps: false
2023-03-17 11:53:27 +01:00
},
logging: false
2023-02-19 16:12:09 +01:00
};
2023-02-19 15:19:46 +01:00
/** @type Sequelize */
2023-02-19 10:54:30 +01:00
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);
}
db.User = require('./user')(sequelize, sequelize.DataTypes);
db.Guestbook = require('./guestbook')(sequelize, sequelize.DataTypes);
db.Article = require('./article')(sequelize, sequelize.DataTypes);
2023-02-19 10:54:30 +01:00
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
2023-02-20 07:54:08 +01:00
sequelize.sync();
2023-02-19 10:54:30 +01:00
module.exports = db;