var md5 = require('md5');
var _ = require('lodash');
var moment = require('moment');
-var VoiceQueue = require('.').VoiceQueue;
module.exports = function(sequelize, DataTypes) {
var User = sequelize.define('User', {
name: {
type: DataTypes.STRING,
- unique: true,
+ unique: 'name',
validate: {
notEmpty: true,
is: /^[A-Za-z0-9\.\_]+$/i
},
set: function(name) {
- name = name.toLowerCase();
this.setDataValue('name', name);
this.setDataValue('defaultuser', name);
}
fullname: {
type: DataTypes.STRING,
allowNull: false,
- unique: true
},
email: {
type: DataTypes.STRING,
- unique: true,
+ unique: 'email',
isEmail: true,
set: function(email) {
if (email) {
},
internal: {
type: DataTypes.INTEGER(11),
- unique: true,
+ unique: 'internal',
set: function(internal) {
this.setDataValue('internal', internal);
this.setDataValue('accountcode', internal);
voicePause: {
type: DataTypes.BOOLEAN,
defaultValue: false,
- set: function(voicePause) {
- this.setDataValue('voicePause', voicePause);
- if (voicePause) {
- this.setDataValue('queueStatus', 'paused');
- this.setDataValue('queueStatusAt', moment().format(
- "YYYY-MM-DD HH:mm:ss"));
- } else {
- this.setDataValue('queueStatus', 'complete');
- this.setDataValue('queueStatusAt', moment().format(
- "YYYY-MM-DD HH:mm:ss"));
- }
- }
+ // set: function(voicePause) {
+ // this.setDataValue('voicePause', voicePause);
+ // if (voicePause) {
+ // this.setDataValue('queueStatus', 'paused');
+ // this.setDataValue('queueStatusAt', moment().format("YYYY-MM-DD HH:mm:ss"));
+ // } else {
+ // this.setDataValue('queueStatus', 'complete');
+ // this.setDataValue('queueStatusAt', moment().format("YYYY-MM-DD HH:mm:ss"));
+ // }
+ // }
},
chatPause: {
type: DataTypes.BOOLEAN,
type: DataTypes.BOOLEAN,
defaultValue: false
},
+ openchannelPause: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
pauseType: {
type: DataTypes.STRING,
defaultValue: 'Default Pause'
type: DataTypes.INTEGER,
defaultValue: 0
},
+ openchannelCapacity: {
+ type: DataTypes.INTEGER,
+ defaultValue: 0
+ },
phoneBarAutoAnswer: {
type: DataTypes.BOOLEAN,
defaultValue: false
type: DataTypes.STRING,
allowNull: true,
},
+ host: {
+ type: DataTypes.STRING,
+ allowNull: true,
+ defaultValue: 'dynamic'
+ },
ipaddr: { //REALTIME ASTERISK
type: DataTypes.STRING,
allowNull: true,
'PROHIB_FAILED_SCREEN', 'PROHIB'),
allowNull: true,
},
- permit: {
+ deny: {
type: DataTypes.STRING,
allowNull: true,
},
- deny: {
+ permit: {
type: DataTypes.STRING,
allowNull: true,
},
type: DataTypes.STRING,
allowNull: true
},
- allow: {
+ disallow: {
type: DataTypes.STRING,
allowNull: true,
- defaultValue: 'alaw;ulaw;gsm'
+ defaultValue: 'all'
},
- disallow: {
+ allow: {
type: DataTypes.STRING,
allowNull: true,
- defaultValue: null
+ defaultValue: 'ulaw;gsm'
},
autoframing: {
type: DataTypes.ENUM('yes', 'no'),
type: DataTypes.STRING,
allowNull: true,
},
- host: {
- type: DataTypes.STRING,
- allowNull: true,
- defaultValue: 'dynamic'
- },
qualify: {
type: DataTypes.ENUM('yes', 'no'),
allowNull: true,
call_limit: {
type: DataTypes.INTEGER(11),
allowNull: true,
- defaultValue: null
+ defaultValue: 10
},
registertrying: { //Send a 100 Trying when the device registers.
type: DataTypes.ENUM('yes', 'no'),
allowNull: true,
defaultValue: 'no'
},
+ loginInPause: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
+ resetPasswordToken: {
+ type: DataTypes.STRING
+ },
+ resetPasswordExpires: {
+ type: DataTypes.DATE
+ },
+ phoneBarEnableRecording: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: true
+ },
+ showWebBar: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
+ phoneBarShowOmniDesktop: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: true
+ },
+ phoneBarRingInUse: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
+ phoneBarDnd: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: true
+ },
+ phoneBarUnansweredCallBadge: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: true
+ },
+ phonebarEnableDtmfTone: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
+ phonebarAutoAnswerDelay: {
+ type: DataTypes.INTEGER,
+ defaultValue: 0
+ }
}, {
tableName: 'users',
+ charset: 'utf8',
+ collate: 'utf8_bin',
instanceMethods: {
/**
* Authenticate - check if the passwords are the same
through: models.UserHasModule,
required: false
});
+ User.belongsToMany(models.MailRoom, {
+ through: models.UserHasMailRoom,
+ });
User.belongsToMany(models.Channel, {
through: 'user_has_channels'
});
- User.belongsToMany(models.MailRoom, {
- through: 'user_has_mail_rooms'
- });
User.belongsToMany(models.SmsRoom, {
through: 'user_has_sms_rooms'
});
+ User.belongsToMany(models.OpenchannelRoom, {
+ through: 'user_has_openchannel_rooms'
+ });
User.belongsToMany(models.FaxRoom, {
through: 'user_has_fax_rooms'
});
through: models.UserHasSmsQueuePermit,
as: 'PSmsQueues'
});
-
+ User.belongsToMany(models.OpenchannelQueue, {
+ through: models.UserHasOpenchannelQueue,
+ required: false
+ });
+ User.belongsToMany(models.OpenchannelQueue, {
+ through: models.UserHasOpenchannelQueuePermit,
+ as: 'POpenchannelQueues'
+ });
User.belongsToMany(models.MailQueue, {
through: models.UserHasMailQueuePermit,
as: 'PMailQueues'
'fullcontact',
'port',
'lastms',
- 'description'
+ 'description',
+ 'callgroup',
+ 'pickupgroup'
]
});
'fullcontact',
'port',
'lastms',
- 'description'
+ 'description',
+ 'callgroup',
+ 'pickupgroup'
]
});
User.addScope('agent', {
'mailCapacity',
'faxCapacity',
'smsCapacity',
+ 'openchannelCapacity',
'online',
'lastLoginAt',
'phoneBarAutoAnswer',
'phoneBarExpires',
'phoneBarRemoteControl',
'phoneBarRemoteControlPort',
+ 'phoneBarEnableRecording',
'chanspy',
'voicePause',
'mailPause',
'faxPause',
'chatPause',
'smsPause',
+ 'openchannelPause',
'pauseType',
'lastPauseAt',
'status',
'fullcontact',
'port',
'lastms',
- 'description'
+ 'description',
+ 'loginInPause',
+ 'showWebBar',
+ 'callgroup',
+ 'pickupgroup',
+ 'phoneBarShowOmniDesktop',
+ 'phoneBarRingInUse',
+ 'phoneBarDnd',
+ 'phoneBarUnansweredCallBadge',
+ 'phone',
+ 'mobile',
+ 'phonebarEnableDtmfTone',
+ 'phonebarAutoAnswerDelay'
]
});
User.addScope('telephone', {
}
});
User.addScope('queues', {
- include: [models.VoiceQueue, models.ChatQueue, models.MailQueue,
- models.FaxQueue, models.SmsQueue
- ]
+ include: [{
+ model: models.VoiceQueue,
+ required: false
+ }, {
+ model: models.ChatQueue,
+ required: false
+ }, {
+ model: models.MailQueue,
+ required: false
+ }, {
+ model: models.FaxQueue,
+ required: false
+ }, {
+ model: models.SmsQueue,
+ required: false
+ }, {
+ model: models.OpenchannelQueue,
+ required: false
+ }]
});
User.addScope('checkPauseStatus', function(query) {
scope.where.smsPause = (query.smsPause === 'true') ?
true : false;
delete query.smsPause;
+ } else if (query.openchannelPause) {
+ scope.where.openchannelPause = (query.openchannelPause === 'true') ?
+ true : false;
+ delete query.openchannelPause;
}
return scope;
});
}
return scope;
});
- User.addScope('checkQueueStatus', function(query) {
+ User.addScope('checkQueueStatus', function(query) { //to be executed before checkOnlineStatus
var scope = {
where: {}
};
if (query.queueStatus) {
- scope.where.queueStatus = query.queueStatus;
+ if (query.queueStatus === 'paused') {
+ scope.where.voicePause = true;
+ } else {
+ scope.where.queueStatus = query.queueStatus;
+ scope.where.voicePause = false;
+ query.online = 'true';
+ }
delete query.queueStatus;
}
return scope;
});
+
+ User.addScope('me', function(userId) {
+ var scope = {
+ where: {
+ id: userId
+ },
+ attributes: ['id', 'fullname', 'name', 'email', 'role', 'userpic', 'lastLoginAt', 'voicePause',
+ 'mailPause',
+ 'chatPause',
+ 'faxPause',
+ 'smsPause',
+ 'openchannelPause',
+ 'lastPauseAt',
+ 'pauseType',
+ 'phoneBarRemoteControl',
+ 'phoneBarRemoteControlPort',
+ 'loginInPause',
+ 'showWebBar',
+ 'phonebarEnableDtmfTone',
+ 'phonebarAutoAnswerDelay'
+ ],
+ include: [{
+ model: models.Module,
+ attributes: ['id', 'path'],
+ include: [{
+ model: models.Module,
+ attributes: ['id', 'path'],
+ as: 'SubModules',
+ required: false,
+ include: [{
+ model: models.Module,
+ attributes: ['id', 'path'],
+ as: 'SubModules'
+ }]
+ }]
+ }]
+ };
+ return scope;
+ });
}
});