6 module.exports = function(sequelize, DataTypes) {
7 var MailRoom = sequelize.define('MailRoom', {
8 subject: DataTypes.STRING,
9 from: DataTypes.STRING,
10 account: DataTypes.STRING,
12 type: DataTypes.BOOLEAN,
16 type: DataTypes.INTEGER,
20 type: DataTypes.INTEGER,
24 type: DataTypes.ENUM('NEW', 'OPEN', 'CLOSED', 'UNMANAGED'),
28 type: DataTypes.ENUM('SENT', 'SENDING', 'RECEIVED', 'FAILED', 'NOTE')
34 type: DataTypes.BOOLEAN,
41 if (this.getDataValue('tags')) {
42 tags = this.getDataValue('tags').split(';');
50 this.setDataValue('tags', val && val.length ? val.join(';') + ';' : null);
54 type: DataTypes.STRING
60 tableName: 'mail_rooms',
62 associate: function(models) {
64 MailRoom.hasMany(models.MailMessage);
65 MailRoom.belongsTo(models.MailAccount);
66 MailRoom.belongsToMany(models.User, {
67 through: 'user_has_mail_rooms'
70 MailRoom.addScope('default', {
75 model: models.MailAccount
77 model: models.MailMessage,
79 model: models.MailAttachment
82 attributes: ['id', 'name', 'fullname', 'email', 'userpic']
86 attributes: ['id', 'name', 'fullname', 'email', 'userpic']