2019-11-23 20:34:31 +00:00
|
|
|
import {DataTypes} from 'sequelize';
|
2016-07-30 03:21:38 +00:00
|
|
|
|
2019-11-23 20:34:31 +00:00
|
|
|
|
2019-11-23 21:12:41 +00:00
|
|
|
function createAuthorModel(sequelize) {
|
2019-11-23 20:34:31 +00:00
|
|
|
const Author = sequelize.define('Author', {
|
2017-03-08 10:45:51 +00:00
|
|
|
id: {
|
2019-11-23 20:34:31 +00:00
|
|
|
type: DataTypes.INTEGER,
|
2017-03-08 10:45:51 +00:00
|
|
|
primaryKey: true,
|
|
|
|
autoIncrement: true
|
|
|
|
},
|
|
|
|
color: {
|
|
|
|
type: DataTypes.STRING
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
indexes: [
|
|
|
|
{
|
|
|
|
unique: true,
|
|
|
|
fields: ['noteId', 'userId']
|
|
|
|
}
|
2019-04-12 04:05:32 +00:00
|
|
|
]
|
2019-11-23 20:34:31 +00:00
|
|
|
});
|
2019-04-12 04:05:32 +00:00
|
|
|
|
|
|
|
Author.associate = function (models) {
|
|
|
|
Author.belongsTo(models.Note, {
|
|
|
|
foreignKey: 'noteId',
|
|
|
|
as: 'note',
|
|
|
|
constraints: false,
|
|
|
|
onDelete: 'CASCADE',
|
|
|
|
hooks: true
|
2019-11-23 20:34:31 +00:00
|
|
|
});
|
2019-04-12 04:05:32 +00:00
|
|
|
Author.belongsTo(models.User, {
|
|
|
|
foreignKey: 'userId',
|
|
|
|
as: 'user',
|
|
|
|
constraints: false,
|
|
|
|
onDelete: 'CASCADE',
|
|
|
|
hooks: true
|
|
|
|
})
|
2019-11-23 20:34:31 +00:00
|
|
|
};
|
2019-04-12 04:05:32 +00:00
|
|
|
|
2017-03-08 10:45:51 +00:00
|
|
|
return Author
|
|
|
|
}
|
2019-11-23 20:34:31 +00:00
|
|
|
|
2019-11-23 21:12:41 +00:00
|
|
|
export = createAuthorModel
|