2018-06-06 21:01:11 +02:00
|
|
|
const Sequelize = require('sequelize');
|
|
|
|
const logger = require('winston');
|
|
|
|
|
2018-10-09 02:02:05 +02:00
|
|
|
const Blocked = require('./blocked');
|
|
|
|
const Certificate = require('./certificate');
|
|
|
|
const Channel = require('./channel');
|
|
|
|
const Claim = require('./claim');
|
|
|
|
const File = require('./file');
|
|
|
|
const Metrics = require('./metrics');
|
|
|
|
const Tor = require('./tor');
|
2018-10-24 10:43:30 +02:00
|
|
|
const Trending = require('./trending');
|
2018-10-09 02:02:05 +02:00
|
|
|
const User = require('./user');
|
2018-10-24 10:43:30 +02:00
|
|
|
const Views = require('./views');
|
2018-03-28 03:25:23 +02:00
|
|
|
|
2018-09-03 01:48:35 +02:00
|
|
|
const {
|
|
|
|
database,
|
|
|
|
username,
|
|
|
|
password,
|
|
|
|
} = require('@config/mysqlConfig');
|
|
|
|
|
2018-06-06 21:01:11 +02:00
|
|
|
if (!database || !username || !password) {
|
|
|
|
logger.warn('missing database, user, or password from mysqlConfig');
|
|
|
|
}
|
2018-03-29 21:21:23 +02:00
|
|
|
|
|
|
|
// set sequelize options
|
|
|
|
const sequelize = new Sequelize(database, username, password, {
|
|
|
|
host : 'localhost',
|
|
|
|
dialect : 'mysql',
|
2018-05-15 00:23:50 +02:00
|
|
|
dialectOptions: {
|
2018-08-01 01:43:08 +02:00
|
|
|
decimalNumbers: true,
|
2018-05-15 00:23:50 +02:00
|
|
|
},
|
2018-08-01 01:43:08 +02:00
|
|
|
logging: false,
|
|
|
|
pool : {
|
2018-03-29 21:21:23 +02:00
|
|
|
max : 5,
|
|
|
|
min : 0,
|
|
|
|
idle : 10000,
|
|
|
|
acquire: 10000,
|
|
|
|
},
|
2018-05-15 00:23:50 +02:00
|
|
|
operatorsAliases: false,
|
2018-03-29 21:21:23 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
// establish mysql connection
|
|
|
|
sequelize
|
|
|
|
.authenticate()
|
|
|
|
.then(() => {
|
|
|
|
logger.info('Sequelize has established mysql connection successfully.');
|
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
logger.error('Sequelize was unable to connect to the database:', err);
|
|
|
|
});
|
|
|
|
|
|
|
|
// manually add each model to the db object (note: make this dynamic)
|
|
|
|
const db = {};
|
2018-12-14 04:55:59 +01:00
|
|
|
|
|
|
|
db['Blocked'] = Blocked(sequelize, Sequelize);
|
|
|
|
db['Certificate'] = Certificate(sequelize, Sequelize);
|
|
|
|
db['Channel'] = Channel(sequelize, Sequelize);
|
|
|
|
db['Claim'] = Claim(sequelize, Sequelize);
|
|
|
|
db['File'] = File(sequelize, Sequelize);
|
|
|
|
db['Metrics'] = Metrics(sequelize, Sequelize);
|
|
|
|
db['Tor'] = Tor(sequelize, Sequelize);
|
|
|
|
db['Trending'] = Trending(sequelize, Sequelize);
|
|
|
|
db['User'] = User(sequelize, Sequelize);
|
|
|
|
db['Views'] = Views(sequelize, Sequelize);
|
2018-03-29 21:21:23 +02:00
|
|
|
|
|
|
|
// run model.association for each model in the db object that has an association
|
|
|
|
logger.info('associating db models...');
|
|
|
|
Object.keys(db).forEach(modelName => {
|
|
|
|
if (db[modelName].associate) {
|
|
|
|
logger.info('Associating model:', modelName);
|
|
|
|
db[modelName].associate(db);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// add sequelize/Sequelize to db
|
|
|
|
db.sequelize = sequelize;
|
|
|
|
db.Sequelize = Sequelize;
|
|
|
|
// add an 'upsert' method to the db object
|
|
|
|
db.upsert = (Model, values, condition, tableName) => {
|
|
|
|
return Model
|
|
|
|
.findOne({
|
|
|
|
where: condition,
|
|
|
|
})
|
|
|
|
.then(obj => {
|
|
|
|
if (obj) { // update
|
|
|
|
logger.debug(`updating record in db.${tableName}`);
|
|
|
|
return obj.update(values);
|
|
|
|
} else { // insert
|
|
|
|
logger.debug(`creating record in db.${tableName}`);
|
|
|
|
return Model.create(values);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(function (error) {
|
|
|
|
logger.error(`${tableName}.upsert error`, error);
|
|
|
|
throw error;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = db;
|