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,
40 return this.getDataValue('tags') ? this.getDataValue('tags').split(';').pop() : [];
43 this.setDataValue('tags', val && val.length ? val.join(';') + ';' : null);
47 type: DataTypes.STRING
53 tableName: 'mail_rooms',
55 associate: function(models) {
57 MailRoom.hasMany(models.MailMessage);
58 MailRoom.belongsTo(models.MailAccount);
59 MailRoom.belongsToMany(models.User, {
60 through: 'user_has_mail_rooms'
63 MailRoom.addScope('default', {
68 model: models.MailAccount
70 model: models.MailMessage,
72 model: models.MailAttachment
75 attributes: ['id', 'name', 'fullname', 'email', 'userpic']
79 attributes: ['id', 'name', 'fullname', 'email', 'userpic']