I have an express server and it does:
app.db = SequelizeData config.db
app.db.sequelize.sync({force: false}).complete (err) ->
console.log err
console.log 'Initialzed database on:'
console.log config.db
SequelizeData is:
(function() {
'use strict';
var Sequelize, fs, path, _;
_ = require('lodash');
fs = require('fs-extra');
path = require('path');
Sequelize = require('sequelize');
module.exports = function(config) {
var db, files, modelPath, myDb, sequelize;
sequelize = new Sequelize(config.database, config.username, config.password, {
dialect: 'postgres',
host: config.host,
port: config.port,
logging: false,
define: {
charset: 'utf8',
collate: 'utf8_general_ci'
}
});
db = {};
modelPath = __dirname + "/models";
files = fs.readdirSync(modelPath);
_.each(files, function(file) {
var model;
if ('.coffee' === path.extname(file)) {
model = sequelize["import"](path.join(modelPath, file));
return db[model.name] = model;
}
});
Object.keys(db).forEach(function(modelName) {
if ('associate' in db[modelName]) {
return db[modelName].associate(db);
}
});
myDb = _.assign(db, {
sequelize: sequelize,
Sequelize: Sequelize
});
return myDb;
};
}).call(this);
which basically walks through my models and adds them to sequelize
. However, although my database exists, it doesn't create any tables. What am I doing wrong?
Thanks!