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.ENUM('NEW', 'OPEN', 'CLOSED', 'UNMANAGED'),
20 type: DataTypes.ENUM('SENT', 'SENDING', 'RECEIVED', 'FAILED', 'NOTE')
25 return this.getDataValue('tags') ? this.getDataValue('tags').split(';') : [];
28 this.setDataValue('tags', val.join(';'));
32 tableName: 'mail_rooms',
34 associate: function(models) {
36 MailRoom.hasMany(models.MailMessage);
37 MailRoom.belongsTo(models.MailAccount);
38 MailRoom.belongsToMany(models.User, {
39 through: 'user_has_mail_rooms'
42 MailRoom.addScope('default', {
47 model: models.MailAccount
49 model: models.MailMessage,
51 model: models.MailAttachment
54 attributes: ['id', 'name', 'fullname', 'email', 'userpic']
58 attributes: ['id', 'name', 'fullname', 'email', 'userpic']