2017-03-14 13:02:43 +08:00
|
|
|
'use strict'
|
2016-07-30 11:21:38 +08:00
|
|
|
// external modules
|
2017-03-08 18:45:51 +08:00
|
|
|
var Sequelize = require('sequelize')
|
2016-07-30 11:21:38 +08:00
|
|
|
|
|
|
|
module.exports = function (sequelize, DataTypes) {
|
2017-03-08 18:45:51 +08:00
|
|
|
var Author = sequelize.define('Author', {
|
|
|
|
id: {
|
|
|
|
type: Sequelize.INTEGER,
|
|
|
|
primaryKey: true,
|
|
|
|
autoIncrement: true
|
|
|
|
},
|
|
|
|
color: {
|
|
|
|
type: DataTypes.STRING
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
indexes: [
|
|
|
|
{
|
|
|
|
unique: true,
|
|
|
|
fields: ['noteId', 'userId']
|
|
|
|
}
|
|
|
|
],
|
|
|
|
classMethods: {
|
|
|
|
associate: function (models) {
|
|
|
|
Author.belongsTo(models.Note, {
|
|
|
|
foreignKey: 'noteId',
|
|
|
|
as: 'note',
|
2018-05-25 14:54:00 +02:00
|
|
|
constraints: false,
|
|
|
|
onDelete: 'CASCADE',
|
|
|
|
hooks: true
|
2017-03-08 18:45:51 +08:00
|
|
|
})
|
|
|
|
Author.belongsTo(models.User, {
|
|
|
|
foreignKey: 'userId',
|
|
|
|
as: 'user',
|
2018-05-25 14:54:00 +02:00
|
|
|
constraints: false,
|
|
|
|
onDelete: 'CASCADE',
|
|
|
|
hooks: true
|
2017-03-08 18:45:51 +08:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
return Author
|
|
|
|
}
|