Sails.js V1 hook to use sequelize ORM V4
Install this hook with:
$ npm install sails-hook-sequeliz --save
.sailsrc
{
"hooks": {
"orm": false,
"pubsub": false
}
}
Also you can set some parameters in config/sequelize.js
to override defaults.
module.exports.sequelize = {
"clsNamespace": "myAppCLSNamespace",
"exposeToGlobal": true
};
Sequelize connection
somePostgresqlServer: {
user: 'postgres',
password: '',
database: 'sequelize',
dialect: 'postgres',
options: {
dialect: 'postgres',
host : 'localhost',
port : 5432,
logging: console.log // or specify sails log level to use ('info', 'warn', 'verbose', etc)
}
}
Sequelize model definition models/user.js
module.exports = {
attributes: {
name: {
type: Sequelize.STRING,
allowNull: false
},
age: {
type: Sequelize.INTEGER
}
},
associations: function() {
user.hasMany(image, {
foreignKey: {
name: 'owner',
allowNull: false
}
});
},
defaultScope: function() {
return {
include: [
{model: image, as: 'images'}
]
}
},
options: {
tableName: 'user',
classMethods: {},
instanceMethods: {},
hooks: {},
scopes: {},
connection: 'NotDefaultModelsConnection' // Can be omitted, so default sails.config.models.connection will be used
}
};
Modified by Raymond FEST to match with Sails V0.12 old version applications
This project was originally created by Gergely Munkácsy (@festo). Now is maintained by Konstantin Burkalev (@KSDaemon).
MIT [github-url]: https://github.com/aristot/sails-hook-sequeliz.git