2018-06-06 12:01:11 -07:00
|
|
|
const Sequelize = require('sequelize');
|
|
|
|
const logger = require('winston');
|
|
|
|
|
2018-10-08 19:02:05 -05: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 03:43:30 -05:00
|
|
|
const Trending = require('./trending');
|
2018-10-08 19:02:05 -05:00
|
|
|
const User = require('./user');
|
2018-10-24 03:43:30 -05:00
|
|
|
const Views = require('./views');
|
2018-03-27 18:25:23 -07:00
|
|
|
|
2018-09-02 18:48:35 -05:00
|
|
|
const {
|
|
|
|
database,
|
|
|
|
username,
|
|
|
|
password,
|
|
|
|
} = require('@config/mysqlConfig');
|
|
|
|
|
2018-06-06 12:01:11 -07:00
|
|
|
if (!database || !username || !password) {
|
|
|
|
logger.warn('missing database, user, or password from mysqlConfig');
|
|
|
|
}
|
2018-03-29 12:21:23 -07:00
|
|
|
|
|
|
|
// set sequelize options
|
|
|
|
const sequelize = new Sequelize(database, username, password, {
|
|
|
|
host : 'localhost',
|
|
|
|
dialect : 'mysql',
|
2018-05-14 15:23:50 -07:00
|
|
|
dialectOptions: {
|
2018-07-31 16:43:08 -07:00
|
|
|
decimalNumbers: true,
|
2018-05-14 15:23:50 -07:00
|
|
|
},
|
2018-07-31 16:43:08 -07:00
|
|
|
logging: false,
|
|
|
|
pool : {
|
2018-03-29 12:21:23 -07:00
|
|
|
max : 5,
|
|
|
|
min : 0,
|
|
|
|
idle : 10000,
|
|
|
|
acquire: 10000,
|
|
|
|
},
|
2018-05-14 15:23:50 -07:00
|
|
|
operatorsAliases: false,
|
2018-03-29 12:21:23 -07: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-10-08 19:02:05 -05:00
|
|
|
db['Blocked'] = sequelize.import('Blocked', Blocked);
|
2018-03-29 12:21:23 -07:00
|
|
|
db['Certificate'] = sequelize.import('Certificate', Certificate);
|
|
|
|
db['Channel'] = sequelize.import('Channel', Channel);
|
|
|
|
db['Claim'] = sequelize.import('Claim', Claim);
|
|
|
|
db['File'] = sequelize.import('File', File);
|
2018-10-08 19:02:05 -05:00
|
|
|
db['Metrics'] = sequelize.import('Metrics', Metrics);
|
2018-06-27 15:11:25 -07:00
|
|
|
db['Tor'] = sequelize.import('Tor', Tor);
|
2018-10-24 03:43:30 -05:00
|
|
|
db['Trending'] = sequelize.import('Trending', Trending);
|
2018-10-08 19:02:05 -05:00
|
|
|
db['User'] = sequelize.import('User', User);
|
2018-10-24 03:43:30 -05:00
|
|
|
db['Views'] = sequelize.import('Views', Views);
|
2018-03-29 12:21:23 -07: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;
|