2016-06-19 18:02:32 +08:00
|
|
|
const Sequelize = require('sequelize');
|
|
|
|
const fs = require('fs');
|
|
|
|
const path = require('path');
|
2016-06-24 07:28:51 +08:00
|
|
|
const HookTransactionLog = require('./hook-transaction-log');
|
|
|
|
const HookAccountCRUD = require('./hook-account-crud');
|
2016-06-30 02:22:38 +08:00
|
|
|
const HookIncrementVersionOnSave = require('./hook-increment-version-on-save');
|
2016-06-19 18:02:32 +08:00
|
|
|
|
2016-06-23 03:16:28 +08:00
|
|
|
require('./database-extensions'); // Extends Sequelize on require
|
|
|
|
|
2016-06-23 08:19:48 +08:00
|
|
|
const STORAGE_DIR = path.join(__dirname, '..', '..', 'storage');
|
2016-06-19 18:02:32 +08:00
|
|
|
if (!fs.existsSync(STORAGE_DIR)) {
|
|
|
|
fs.mkdirSync(STORAGE_DIR);
|
|
|
|
}
|
|
|
|
|
2016-06-23 15:49:22 +08:00
|
|
|
class DatabaseConnector {
|
2016-06-19 18:02:32 +08:00
|
|
|
constructor() {
|
|
|
|
this._pools = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
_readModelsInDirectory(sequelize, dirname) {
|
|
|
|
const db = {};
|
|
|
|
for (const filename of fs.readdirSync(dirname)) {
|
|
|
|
if (filename.endsWith('.js')) {
|
|
|
|
const model = sequelize.import(path.join(dirname, filename));
|
2016-06-30 01:36:32 +08:00
|
|
|
db[model.name[0].toUpperCase() + model.name.substr(1)] = model;
|
2016-06-19 18:02:32 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
Object.keys(db).forEach((modelName) => {
|
|
|
|
if ("associate" in db[modelName]) {
|
|
|
|
db[modelName].associate(db);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return db;
|
|
|
|
}
|
|
|
|
|
|
|
|
_sequelizeForAccount(accountId) {
|
2016-06-21 05:57:54 +08:00
|
|
|
if (!accountId) {
|
2016-06-28 07:01:21 +08:00
|
|
|
return Promise.reject(new NylasError(`You need to pass an accountId to init the database!`))
|
2016-06-21 05:57:54 +08:00
|
|
|
}
|
2016-06-19 18:02:32 +08:00
|
|
|
const sequelize = new Sequelize(accountId, '', '', {
|
|
|
|
storage: path.join(STORAGE_DIR, `a-${accountId}.sqlite`),
|
|
|
|
dialect: "sqlite",
|
2016-06-21 05:44:02 +08:00
|
|
|
logging: false,
|
2016-06-19 18:02:32 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
const modelsPath = path.join(__dirname, 'models/account');
|
|
|
|
const db = this._readModelsInDirectory(sequelize, modelsPath)
|
|
|
|
|
2016-06-30 02:22:38 +08:00
|
|
|
HookTransactionLog(db, sequelize);
|
|
|
|
HookIncrementVersionOnSave(db, sequelize);
|
|
|
|
|
2016-06-19 18:02:32 +08:00
|
|
|
db.sequelize = sequelize;
|
|
|
|
db.Sequelize = Sequelize;
|
2016-06-21 05:57:54 +08:00
|
|
|
db.accountId = accountId;
|
2016-06-19 18:02:32 +08:00
|
|
|
|
|
|
|
return sequelize.authenticate().then(() =>
|
|
|
|
sequelize.sync()
|
|
|
|
).thenReturn(db);
|
|
|
|
}
|
|
|
|
|
|
|
|
forAccount(accountId) {
|
|
|
|
this._pools[accountId] = this._pools[accountId] || this._sequelizeForAccount(accountId);
|
|
|
|
return this._pools[accountId];
|
|
|
|
}
|
|
|
|
|
|
|
|
_sequelizeForShared() {
|
|
|
|
const sequelize = new Sequelize('shared', '', '', {
|
|
|
|
storage: path.join(STORAGE_DIR, 'shared.sqlite'),
|
|
|
|
dialect: "sqlite",
|
2016-06-21 05:44:02 +08:00
|
|
|
logging: false,
|
2016-06-19 18:02:32 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
const modelsPath = path.join(__dirname, 'models/shared');
|
|
|
|
const db = this._readModelsInDirectory(sequelize, modelsPath)
|
|
|
|
|
2016-06-30 02:22:38 +08:00
|
|
|
HookAccountCRUD(db, sequelize);
|
|
|
|
|
2016-06-19 18:02:32 +08:00
|
|
|
db.sequelize = sequelize;
|
|
|
|
db.Sequelize = Sequelize;
|
|
|
|
|
|
|
|
return sequelize.authenticate().then(() =>
|
|
|
|
sequelize.sync()
|
|
|
|
).thenReturn(db);
|
|
|
|
}
|
|
|
|
|
|
|
|
forShared() {
|
|
|
|
this._pools.shared = this._pools.shared || this._sequelizeForShared();
|
|
|
|
return this._pools.shared;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-23 15:49:22 +08:00
|
|
|
module.exports = new DatabaseConnector()
|