mirror of
https://github.com/Mibew/tray.git
synced 2025-01-22 10:00:35 +03:00
Update plugins message system.
Now arbitrary data can be attached to any message.
This commit is contained in:
parent
aa38622b8d
commit
fb6517dc9f
@ -202,6 +202,7 @@ class ThreadTest extends PHPUnit_Framework_TestCase {
|
||||
|
||||
'lrevision' => 189,
|
||||
'istate' => Thread::STATE_QUEUE,
|
||||
'invitationstate' => Thread::INVITATION_NOT_INVITED,
|
||||
'ltoken' => 19908,
|
||||
|
||||
'nextagent' => 0,
|
||||
@ -574,15 +575,19 @@ class ThreadTest extends PHPUnit_Framework_TestCase {
|
||||
'agentId' => 12,
|
||||
'tmessage' => 'New message text',
|
||||
'dtmcreated' => time(),
|
||||
'tname' => 'Sender name'
|
||||
'tname' => 'Sender name',
|
||||
'plugin' => '',
|
||||
'data' => array()
|
||||
);
|
||||
|
||||
$message['messageid'] = $thread->postMessage(
|
||||
$message['ikind'],
|
||||
$message['tmessage'],
|
||||
$message['tname'],
|
||||
$message['agentId'],
|
||||
$message['dtmcreated']
|
||||
array(
|
||||
'name' => $message['tname'],
|
||||
'operator_id' => $message['agentId'],
|
||||
'created' => $message['dtmcreated']
|
||||
)
|
||||
);
|
||||
// Load message info from database
|
||||
$msg_info = $db->query(
|
||||
@ -590,6 +595,8 @@ class ThreadTest extends PHPUnit_Framework_TestCase {
|
||||
array($message['messageid']),
|
||||
array('return_rows' => Database::RETURN_ONE_ROW)
|
||||
);
|
||||
$msg_info['data'] = unserialize($msg_info['data']);
|
||||
|
||||
// Check values
|
||||
$this->assertEquals($message, $msg_info);
|
||||
|
||||
@ -613,21 +620,27 @@ class ThreadTest extends PHPUnit_Framework_TestCase {
|
||||
'kind' => Thread::KIND_USER,
|
||||
'message' => 'The first message',
|
||||
'created' => time(),
|
||||
'name' => 'System message only for agent'
|
||||
'name' => 'System message only for agent',
|
||||
'plugin' => 'f_test_plg',
|
||||
'data' => array('msg_num' => 1)
|
||||
);
|
||||
// The second
|
||||
$second_message = array(
|
||||
'kind' => Thread::KIND_AGENT,
|
||||
'message' => 'The second message',
|
||||
'created' => time(),
|
||||
'name' => 'User'
|
||||
'name' => 'User',
|
||||
'plugin' => 'f_test_plg',
|
||||
'data' => array('msg_num' => 1)
|
||||
);
|
||||
// The third
|
||||
$third_message = array(
|
||||
'kind' => Thread::KIND_FOR_AGENT,
|
||||
'message' => 'The third message',
|
||||
'created' => time(),
|
||||
'name' => 'Agent'
|
||||
'name' => 'Agent',
|
||||
'plugin' => 'f_test_plg',
|
||||
'data' => array('msg_num' => 1)
|
||||
);
|
||||
|
||||
// Send messages
|
||||
@ -635,25 +648,37 @@ class ThreadTest extends PHPUnit_Framework_TestCase {
|
||||
$first_message['id'] = $thread->postMessage(
|
||||
$first_message['kind'],
|
||||
$first_message['message'],
|
||||
$first_message['name'],
|
||||
12,
|
||||
$first_message['created']
|
||||
array(
|
||||
'name' => $first_message['name'],
|
||||
'operator_id' => 12,
|
||||
'created' => $first_message['created'],
|
||||
'plugin' => $second_message['plugin'],
|
||||
'data' => $second_message['data']
|
||||
)
|
||||
);
|
||||
// The second
|
||||
$second_message['id'] = $thread->postMessage(
|
||||
$second_message['kind'],
|
||||
$second_message['message'],
|
||||
$second_message['name'],
|
||||
14,
|
||||
$second_message['created']
|
||||
array(
|
||||
'name' => $second_message['name'],
|
||||
'operator_id' => 14,
|
||||
'created' => $second_message['created'],
|
||||
'plugin' => $second_message['plugin'],
|
||||
'data' => $second_message['data']
|
||||
)
|
||||
);
|
||||
// The third
|
||||
$third_message['id'] = $thread->postMessage(
|
||||
$third_message['kind'],
|
||||
$third_message['message'],
|
||||
$third_message['name'],
|
||||
16,
|
||||
$third_message['created']
|
||||
array(
|
||||
'name' => $third_message['name'],
|
||||
'operator_id' => 16,
|
||||
'created' => $third_message['created'],
|
||||
'plugin' => $second_message['plugin'],
|
||||
'data' => $second_message['data']
|
||||
)
|
||||
);
|
||||
|
||||
// Check messages for agent with ids starts from $msg_id
|
||||
|
@ -127,6 +127,11 @@ $dbtables = array(
|
||||
"agentId" => "int NOT NULL DEFAULT 0",
|
||||
// Message text body.
|
||||
"tmessage" => "text NOT NULL",
|
||||
// Name of the plugin which sent the message. If message was not sent by
|
||||
// a plugin this field equals to an empty string.
|
||||
"plugin" => "varchar(256) NOT NULL DEFAULT ''",
|
||||
// Arbitrary serialized data related with message.
|
||||
"data" => "text",
|
||||
// Unix timestamp when message was created.
|
||||
"dtmcreated" => "int NOT NULL DEFAULT 0",
|
||||
// Name of the message sender.
|
||||
@ -266,7 +271,7 @@ $dbtables_can_update = array(
|
||||
"${mysqlprefix}chatthread" => array("agentId", "userTyping", "agentTyping", "messageCount", "nextagent", "shownmessageid", "userid", "userAgent", "groupid", "dtmchatstarted", "invitationstate"),
|
||||
"${mysqlprefix}chatthreadstatistics" => array("missedthreads", "sentinvitations", "acceptedinvitations", "rejectedinvitations", "ignoredinvitations"),
|
||||
"${mysqlprefix}requestbuffer" => array("requestid", "requestkey", "request"),
|
||||
"${mysqlprefix}chatmessage" => array("agentId"),
|
||||
"${mysqlprefix}chatmessage" => array("agentId", "plugin", "data"),
|
||||
"${mysqlprefix}chatoperator" => array("vcavatar", "vcjabbername", "iperm", "istatus", "idisabled", "vcemail", "dtmrestore", "vcrestoretoken", "code"),
|
||||
"${mysqlprefix}chatoperatorstatistics" => array("sentinvitations", "acceptedinvitations", "rejectedinvitations", "ignoredinvitations"),
|
||||
"${mysqlprefix}chatban" => array(),
|
||||
|
@ -91,6 +91,14 @@ if ($act == "silentcreateall") {
|
||||
runsql("update ${mysqlprefix}chatmessage, ${mysqlprefix}chatoperator set agentId = operatorid where agentId = 0 AND ikind = 2 AND (vclocalename = tname OR vccommonname = tname)", $link);
|
||||
}
|
||||
|
||||
if (in_array("${mysqlprefix}chatmessage.plugin", $absent_columns)) {
|
||||
runsql("ALTER TABLE ${mysqlprefix}chatmessage ADD plugin varchar(256) NOT NULL DEFAULT '' AFTER tmessage", $link);
|
||||
}
|
||||
|
||||
if (in_array("${mysqlprefix}chatmessage.data", $absent_columns)) {
|
||||
runsql("ALTER TABLE ${mysqlprefix}chatmessage ADD data text AFTER plugin", $link);
|
||||
}
|
||||
|
||||
if (in_array("${mysqlprefix}chatthread.agentId", $absent_columns)) {
|
||||
runsql("ALTER TABLE ${mysqlprefix}chatthread ADD agentId int NOT NULL DEFAULT 0 AFTER agentName", $link);
|
||||
runsql("update ${mysqlprefix}chatthread, ${mysqlprefix}chatoperator set agentId = operatorid where agentId = 0 AND (vclocalename = agentName OR vccommonname = agentName)", $link);
|
||||
|
@ -6,5 +6,5 @@
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(b,d,j){b.Collections.Messages=d.Collection.extend({model:b.Models.Message,initialize:function(){this.periodicallyCalled=[];this.periodicallyCalled.push(b.Objects.server.callFunctionsPeriodically(j.bind(this.updateMessagesFunctionBuilder,this),j.bind(this.updateMessages,this)))},finalize:function(){for(var a=0;a<this.periodicallyCalled.length;a++)b.Objects.server.stopCallFunctionsPeriodically(this.periodicallyCalled[a])},updateMessages:function(a){a.lastId&&b.Objects.Models.thread.set({lastId:a.lastId});
|
||||
for(var k=b.Models.Message.prototype.KIND_PLUGIN,g=[],c,f,e,h=0,d=a.messages.length;h<d;h++)c=a.messages[h],c.kind!=k?g.push(new b.Models.Message(c)):"object"!=typeof c.message||null===c.message||(f=c.message.plugin||!1,f="process:"+(!1!==f?f+":":"")+"plugin:message",e={messageData:c,model:!1},this.trigger(f,e),e.model&&(e.model.get("id")||e.model.set({id:c.id}),g.push(e.model)));0<g.length&&this.add(g)},updateMessagesFunctionBuilder:function(){var a=b.Objects.Models.thread,d=b.Objects.Models.user;
|
||||
return[{"function":"updateMessages",arguments:{"return":{messages:"messages",lastId:"lastId"},references:{},threadId:a.get("id"),token:a.get("token"),lastId:a.get("lastId"),user:!d.get("isAgent")}}]},add:function(){var a=Array.prototype.slice.apply(arguments),a=d.Collection.prototype.add.apply(this,a);this.trigger("multiple:add");return a}})})(Mibew,Backbone,_);
|
||||
for(var k=b.Models.Message.prototype.KIND_PLUGIN,g=[],c,f,e,h=0,d=a.messages.length;h<d;h++)c=a.messages[h],c.kind!=k?g.push(new b.Models.Message(c)):"object"!=typeof c.data||null===c.data||(f=c.plugin||!1,f="process:"+(!1!==f?f+":":"")+"plugin:message",e={messageData:c,model:!1},this.trigger(f,e),e.model&&(e.model.get("id")||e.model.set({id:c.id}),g.push(e.model)));0<g.length&&this.add(g)},updateMessagesFunctionBuilder:function(){var a=b.Objects.Models.thread,d=b.Objects.Models.user;return[{"function":"updateMessages",
|
||||
arguments:{"return":{messages:"messages",lastId:"lastId"},references:{},threadId:a.get("id"),token:a.get("token"),lastId:a.get("lastId"),user:!d.get("isAgent")}}]},add:function(){var a=Array.prototype.slice.apply(arguments),a=d.Collection.prototype.add.apply(this,a);this.trigger("multiple:add");return a}})})(Mibew,Backbone,_);
|
||||
|
@ -157,8 +157,8 @@ groupId:a.get("groupId"),name:a.get("name"),info:a.get("info"),email:a.get("emai
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(b,d,j){b.Collections.Messages=d.Collection.extend({model:b.Models.Message,initialize:function(){this.periodicallyCalled=[];this.periodicallyCalled.push(b.Objects.server.callFunctionsPeriodically(j.bind(this.updateMessagesFunctionBuilder,this),j.bind(this.updateMessages,this)))},finalize:function(){for(var a=0;a<this.periodicallyCalled.length;a++)b.Objects.server.stopCallFunctionsPeriodically(this.periodicallyCalled[a])},updateMessages:function(a){a.lastId&&b.Objects.Models.thread.set({lastId:a.lastId});
|
||||
for(var k=b.Models.Message.prototype.KIND_PLUGIN,g=[],c,f,e,h=0,d=a.messages.length;h<d;h++)c=a.messages[h],c.kind!=k?g.push(new b.Models.Message(c)):"object"!=typeof c.message||null===c.message||(f=c.message.plugin||!1,f="process:"+(!1!==f?f+":":"")+"plugin:message",e={messageData:c,model:!1},this.trigger(f,e),e.model&&(e.model.get("id")||e.model.set({id:c.id}),g.push(e.model)));0<g.length&&this.add(g)},updateMessagesFunctionBuilder:function(){var a=b.Objects.Models.thread,d=b.Objects.Models.user;
|
||||
return[{"function":"updateMessages",arguments:{"return":{messages:"messages",lastId:"lastId"},references:{},threadId:a.get("id"),token:a.get("token"),lastId:a.get("lastId"),user:!d.get("isAgent")}}]},add:function(){var a=Array.prototype.slice.apply(arguments),a=d.Collection.prototype.add.apply(this,a);this.trigger("multiple:add");return a}})})(Mibew,Backbone,_);
|
||||
for(var k=b.Models.Message.prototype.KIND_PLUGIN,g=[],c,f,e,h=0,d=a.messages.length;h<d;h++)c=a.messages[h],c.kind!=k?g.push(new b.Models.Message(c)):"object"!=typeof c.data||null===c.data||(f=c.plugin||!1,f="process:"+(!1!==f?f+":":"")+"plugin:message",e={messageData:c,model:!1},this.trigger(f,e),e.model&&(e.model.get("id")||e.model.set({id:c.id}),g.push(e.model)));0<g.length&&this.add(g)},updateMessagesFunctionBuilder:function(){var a=b.Objects.Models.thread,d=b.Objects.Models.user;return[{"function":"updateMessages",
|
||||
arguments:{"return":{messages:"messages",lastId:"lastId"},references:{},threadId:a.get("id"),token:a.get("token"),lastId:a.get("lastId"),user:!d.get("isAgent")}}]},add:function(){var a=Array.prototype.slice.apply(arguments),a=d.Collection.prototype.add.apply(this,a);this.trigger("multiple:add");return a}})})(Mibew,Backbone,_);
|
||||
/*
|
||||
Copyright 2005-2013 the original author or authors.
|
||||
Licensed under the Apache License, Version 2.0 (the "License").
|
||||
|
@ -5,4 +5,4 @@
|
||||
You may obtain a copy of the License at
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(a){a.Models.Message=a.Models.Base.extend({defaults:{kind:null,created:0,name:"",message:""},KIND_USER:1,KIND_AGENT:2,KIND_FOR_AGENT:3,KIND_INFO:4,KIND_CONN:5,KIND_EVENTS:6,KIND_PLUGIN:7})})(Mibew);
|
||||
(function(a){a.Models.Message=a.Models.Base.extend({defaults:{kind:null,created:0,name:"",message:"",plugin:"",data:{}},KIND_USER:1,KIND_AGENT:2,KIND_FOR_AGENT:3,KIND_INFO:4,KIND_CONN:5,KIND_EVENTS:6,KIND_PLUGIN:7})})(Mibew);
|
||||
|
@ -73,7 +73,7 @@ b.Utils.playSound=function(a){c("body").append('<audio autoplay style="display:
|
||||
You may obtain a copy of the License at
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(a){a.Models.Message=a.Models.Base.extend({defaults:{kind:null,created:0,name:"",message:""},KIND_USER:1,KIND_AGENT:2,KIND_FOR_AGENT:3,KIND_INFO:4,KIND_CONN:5,KIND_EVENTS:6,KIND_PLUGIN:7})})(Mibew);
|
||||
(function(a){a.Models.Message=a.Models.Base.extend({defaults:{kind:null,created:0,name:"",message:"",plugin:"",data:{}},KIND_USER:1,KIND_AGENT:2,KIND_FOR_AGENT:3,KIND_INFO:4,KIND_CONN:5,KIND_EVENTS:6,KIND_PLUGIN:7})})(Mibew);
|
||||
/*
|
||||
Copyright 2005-2013 the original author or authors.
|
||||
Licensed under the Apache License, Version 2.0 (the "License").
|
||||
|
@ -5,4 +5,4 @@
|
||||
You may obtain a copy of the License at
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(b,c){var a=new c.Marionette.Application;a.addRegions({messagesRegion:"#messages-region"});a.addInitializer(function(c){a.messagesRegion.show(new b.Views.MessagesCollection({collection:new b.Collections.Messages(c.messages)}))});b.Application=a})(Mibew,Backbone);
|
||||
(function(a,c){var b=new c.Marionette.Application;b.addRegions({messagesRegion:"#messages-region"});b.addInitializer(function(c){var d=new a.Collections.Messages;a.Objects.Collections.messages=d;d.updateMessages(c.messages);b.messagesRegion.show(new a.Views.MessagesCollection({collection:d}))});a.Application=b})(Mibew,Backbone);
|
||||
|
@ -5,4 +5,4 @@
|
||||
You may obtain a copy of the License at
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(a,b){a.Collections.Messages=b.Collection.extend({model:a.Models.Message})})(Mibew,Backbone,_);
|
||||
(function(d,e){d.Collections.Messages=e.Collection.extend({model:d.Models.Message,updateMessages:function(b){for(var c=[],a=0;a<b.length;a++)b[a].message&&c.push(b[a]);0<c.length&&this.add(c)}})})(Mibew,Backbone,_);
|
||||
|
@ -4,7 +4,7 @@
|
||||
You may obtain a copy of the License at
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(a,b){a.Collections.Messages=b.Collection.extend({model:a.Models.Message})})(Mibew,Backbone,_);
|
||||
(function(d,e){d.Collections.Messages=e.Collection.extend({model:d.Models.Message,updateMessages:function(b){for(var c=[],a=0;a<b.length;a++)b[a].message&&c.push(b[a]);0<c.length&&this.add(c)}})})(Mibew,Backbone,_);
|
||||
/*
|
||||
Copyright 2005-2013 the original author or authors.
|
||||
Licensed under the Apache License, Version 2.0 (the "License").
|
||||
@ -18,4 +18,4 @@
|
||||
You may obtain a copy of the License at
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
*/
|
||||
(function(b,c){var a=new c.Marionette.Application;a.addRegions({messagesRegion:"#messages-region"});a.addInitializer(function(c){a.messagesRegion.show(new b.Views.MessagesCollection({collection:new b.Collections.Messages(c.messages)}))});b.Application=a})(Mibew,Backbone);
|
||||
(function(a,c){var b=new c.Marionette.Application;b.addRegions({messagesRegion:"#messages-region"});b.addInitializer(function(c){var d=new a.Collections.Messages;a.Objects.Collections.messages=d;d.updateMessages(c.messages);b.messagesRegion.show(new a.Views.MessagesCollection({collection:d}))});a.Application=b})(Mibew,Backbone);
|
||||
|
@ -81,15 +81,10 @@
|
||||
|
||||
// Message have KIND_PLUGIN kind and need to be processed
|
||||
// by plugins to know how to display it.
|
||||
//
|
||||
// Message treat as data object with following fields:
|
||||
// - 'plugin': string, name of the plugin which sent the
|
||||
// message;
|
||||
// - 'data': object, some data sent by the plugin.
|
||||
|
||||
// Check if message is an real Object
|
||||
if ((typeof messageData.message != 'object')
|
||||
|| (messageData.message === null)) {
|
||||
if ((typeof messageData.data != 'object')
|
||||
|| (messageData.data === null)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -98,7 +93,7 @@
|
||||
// If plugin name was specified it will be
|
||||
// 'process:<plugin_name>:plugin:message' and
|
||||
// 'process:plugin:message' otherwise.
|
||||
pluginName = messageData.message.plugin || false;
|
||||
pluginName = messageData.plugin || false;
|
||||
eventName = 'process:'
|
||||
+ ((pluginName !== false) ? pluginName + ':' : '')
|
||||
+ 'plugin:message';
|
||||
|
@ -40,7 +40,20 @@
|
||||
* Text of the message
|
||||
* @type String
|
||||
*/
|
||||
message: ''
|
||||
message: '',
|
||||
|
||||
/**
|
||||
* Name of the plugin which sent the message. If message was not
|
||||
* sent by a plugin it equals to an empty string.
|
||||
* @type String
|
||||
*/
|
||||
plugin: '',
|
||||
|
||||
/**
|
||||
* Set of arbitrary data attached to the message.
|
||||
* @type Object
|
||||
*/
|
||||
data: {}
|
||||
},
|
||||
|
||||
/** Message kind constants */
|
||||
|
@ -18,8 +18,16 @@
|
||||
|
||||
// Initialize application
|
||||
App.addInitializer(function(options){
|
||||
// Create new empty messages collection and store it
|
||||
var messages = new Mibew.Collections.Messages();
|
||||
Mibew.Objects.Collections.messages = messages;
|
||||
|
||||
// Update messages in the collection
|
||||
messages.updateMessages(options.messages);
|
||||
|
||||
// Dispaly collection
|
||||
App.messagesRegion.show(new Mibew.Views.MessagesCollection({
|
||||
collection: new Mibew.Collections.Messages(options.messages)
|
||||
collection: messages
|
||||
}));
|
||||
});
|
||||
|
||||
|
@ -18,7 +18,29 @@
|
||||
* Default contructor for model
|
||||
* @type Function
|
||||
*/
|
||||
model: Mibew.Models.Message
|
||||
model: Mibew.Models.Message,
|
||||
|
||||
/**
|
||||
* Update messages in collection.
|
||||
*
|
||||
* Skip messages with empty text body.
|
||||
* @param rawMessages {Array} Array of row message models data.
|
||||
*/
|
||||
updateMessages: function(rawMessages) {
|
||||
// Reject all messages with empty text body
|
||||
var newMessages = [];
|
||||
for(var i = 0; i < rawMessages.length; i++) {
|
||||
if (! rawMessages[i].message) {
|
||||
continue;
|
||||
}
|
||||
newMessages.push(rawMessages[i]);
|
||||
}
|
||||
|
||||
// Add new messages to the collection
|
||||
if (newMessages.length > 0) {
|
||||
this.add(newMessages);
|
||||
}
|
||||
}
|
||||
}
|
||||
);
|
||||
|
||||
|
@ -563,9 +563,10 @@ Class Thread {
|
||||
$this->postMessage(
|
||||
self::KIND_CONN,
|
||||
$message_to_post,
|
||||
null,
|
||||
null,
|
||||
$last_ping_other_side + self::CONNECTION_TIMEOUT
|
||||
array(
|
||||
'created' => $last_ping_other_side
|
||||
+ self::CONNECTION_TIMEOUT
|
||||
)
|
||||
);
|
||||
|
||||
// And update thread
|
||||
@ -582,9 +583,10 @@ Class Thread {
|
||||
$this->postMessage(
|
||||
self::KIND_FOR_AGENT,
|
||||
$message_to_post,
|
||||
null,
|
||||
null,
|
||||
$last_ping_other_side + self::CONNECTION_TIMEOUT
|
||||
array(
|
||||
'created' => $last_ping_other_side
|
||||
+ self::CONNECTION_TIMEOUT
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -690,8 +692,10 @@ Class Thread {
|
||||
* - 'kind': int, message kind, see Thread::KIND_* for details;
|
||||
* - 'created': int, unix timestamp when message was created;
|
||||
* - 'name': string, name of sender;
|
||||
* - 'message': associative array with message data if kind equals to
|
||||
* Thread::KIND_PLUGIN and message text string otherwise.
|
||||
* - 'message': string, message text;
|
||||
* - 'plugin': string, name of the plugin which sent the message or an
|
||||
* empty string if message was not sent by a plugin.
|
||||
* - 'data' array, arbitrary data attached to the message
|
||||
* @see Thread::postMessage()
|
||||
*/
|
||||
public function getMessages($is_user, &$last_id) {
|
||||
@ -702,7 +706,7 @@ Class Thread {
|
||||
// Load messages
|
||||
$messages = $db->query(
|
||||
"select messageid as id, ikind as kind, dtmcreated as created, " .
|
||||
" tname as name, tmessage as message " .
|
||||
" tname as name, tmessage as message, plugin, data " .
|
||||
"from {chatmessage} " .
|
||||
"where threadid = :threadid and messageid > :lastid " .
|
||||
($is_user ? "and ikind <> " . self::KIND_FOR_AGENT : "") .
|
||||
@ -722,20 +726,21 @@ Class Thread {
|
||||
$msg['name']
|
||||
);
|
||||
|
||||
// Process message body
|
||||
if ($messages[$key]['kind'] == self::KIND_PLUGIN) {
|
||||
// Treat plugin message body as an associative array
|
||||
$messages[$key]['message'] = unserialize(
|
||||
$messages[$key]['message']
|
||||
// Process data attached to the message
|
||||
if (! empty($messages[$key]['data'])) {
|
||||
$messages[$key]['data'] = unserialize(
|
||||
$messages[$key]['data']
|
||||
);
|
||||
} else {
|
||||
// Change message body encoding for core messages kinds
|
||||
$messages[$key]['data'] = array();
|
||||
}
|
||||
|
||||
// Change message body encoding
|
||||
$messages[$key]['message'] = myiconv(
|
||||
$webim_encoding,
|
||||
"utf-8",
|
||||
$msg['message']
|
||||
);
|
||||
}
|
||||
|
||||
// Get last message ID
|
||||
if ($msg['id'] > $last_id) {
|
||||
@ -749,20 +754,30 @@ Class Thread {
|
||||
/**
|
||||
* Send the messsage
|
||||
*
|
||||
* Use to send message with one of the core kinds(not Thread::KIND_PLUGIN).
|
||||
* Trigger error with 'E_USER_WARNING' level if $kind equals to
|
||||
* Thread::KIND_PLUGIN.
|
||||
* One can attach arbitrary data to the message by setting 'data' item
|
||||
* in the $options array. DO NOT serialize data manually - it will be
|
||||
* automatically coverted to array and serialized before save in database
|
||||
* and unserialized after retreive form database.
|
||||
*
|
||||
* To send plugin message use Thread::postPluginMessage instead.
|
||||
* One can also set plugin item of the $options array to indicate that
|
||||
* message was sent by a plugin.
|
||||
*
|
||||
* @param int $kind Message kind. One of the Thread::KIND_* but not
|
||||
* Thread::KIND_PLUGIN
|
||||
* @param int $kind Message kind. One of the Thread::KIND_*
|
||||
* @param string $message Message body
|
||||
* @param string|null $from Sender name
|
||||
* @param int|null $opid operator id. Use NULL for system messages
|
||||
* @param int|null $time unix timestamp of the send time. Use NULL for
|
||||
* current time.
|
||||
* @return int|boolean Message ID or boolean false on failure.
|
||||
* @param array $options List of additional options. It may contain
|
||||
* following items:
|
||||
* - 'name': string, name of the message sender.
|
||||
* - 'operator_id': int, ID of the operator who sent the message. For
|
||||
* system messages do not set this field.
|
||||
* - 'created': int, unix timestamp of the send time. If you want to set
|
||||
* current time do not set this field.
|
||||
* - 'plugin': string, name of the plugin which sent the message. If
|
||||
* message was not sent by a plugin do not set this field.
|
||||
* - 'data': array with arbitrary data related with message. This value
|
||||
* will be converted to array and serialized before save. If there is no
|
||||
* such data do not set this field.
|
||||
*
|
||||
* @return int Message ID
|
||||
*
|
||||
* @see Thread::KIND_USER
|
||||
* @see Thread::KIND_AGENT
|
||||
@ -774,39 +789,11 @@ Class Thread {
|
||||
* @see Thread::getMessages()
|
||||
* @see Thread::postPluginMessage()
|
||||
*/
|
||||
public function postMessage($kind, $message, $from = null, $opid = null, $time = null) {
|
||||
// Check message kind. It can not be equal to Thread::KIND_PLUGIN
|
||||
if ($kind == self::KIND_PLUGIN) {
|
||||
trigger_error(
|
||||
'Use Thread::postPluginMessage to send plugins messages',
|
||||
E_USER_WARNING
|
||||
);
|
||||
return false;
|
||||
}
|
||||
public function postMessage($kind, $message, $options = array()) {
|
||||
$options = is_array($options) ? $options : array();
|
||||
|
||||
// Send message
|
||||
return $this->saveMessage($kind, $message, $from, $opid, $time);
|
||||
}
|
||||
|
||||
/**
|
||||
* Send plugin messsage
|
||||
*
|
||||
* @param string $plugin Plugin name. Use to determine which plugin sent
|
||||
* the message.
|
||||
* @param array $data Message data. Can contain arbitrary structure.
|
||||
* @param int|null $time unix timestamp of the send time. Use NULL for
|
||||
* current time.
|
||||
* @return int Message ID
|
||||
*
|
||||
* @see Thread::getMessages()
|
||||
*/
|
||||
public function postPluginMessage($plugin, $data, $time = null) {
|
||||
$message = serialize(array(
|
||||
'plugin' => $plugin,
|
||||
'data' => $data
|
||||
));
|
||||
|
||||
return $this->saveMessage(self::KIND_PLUGIN, $message, null, null, $time);
|
||||
return $this->saveMessage($kind, $message, $options);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -814,10 +801,19 @@ Class Thread {
|
||||
*
|
||||
* @param int $kind Message kind. One of the Thread::KIND_*
|
||||
* @param string $message Message body
|
||||
* @param string|null $from Sender name
|
||||
* @param int|null $opid operator id. Use NULL for system messages
|
||||
* @param int|null $time unix timestamp of the send time. Use NULL for
|
||||
* current time.
|
||||
* @param array $options List of additional options. It may contain
|
||||
* following items:
|
||||
* - 'name': string, name of the message sender.
|
||||
* - 'operator_id': int, ID of the operator who sent the message. For
|
||||
* system messages do not set this field.
|
||||
* - 'created': int, unix timestamp of the send time. If you want to set
|
||||
* current time do not set this field.
|
||||
* - 'plugin': string, name of the plugin which sent the message. If
|
||||
* message was not sent by a plugin do not set this field.
|
||||
* - 'data': array with arbitrary data related with message. This value
|
||||
* will be converted to array and serialized before save. If there is no
|
||||
* such data do not set this field.
|
||||
*
|
||||
* @return int Message ID
|
||||
*
|
||||
* @see Thread::KIND_USER
|
||||
@ -829,22 +825,42 @@ Class Thread {
|
||||
* @see Thread::KIND_PLUGIN
|
||||
* @see Thread::getMessages()
|
||||
*/
|
||||
protected function saveMessage($kind, $message, $from = null, $opid = null, $time = null) {
|
||||
protected function saveMessage($kind, $message, $options = array()) {
|
||||
$db = Database::getInstance();
|
||||
|
||||
$query = "INSERT INTO {chatmessage} " .
|
||||
"(threadid,ikind,tmessage,tname,agentId,dtmcreated) " .
|
||||
"VALUES (:threadid,:kind,:message,:name,:agentid,:created)";
|
||||
// Add default values to options
|
||||
$options += array(
|
||||
'name' => null,
|
||||
'operator_id' => 0,
|
||||
'created' => time(),
|
||||
'plugin' => '',
|
||||
'data' => array()
|
||||
);
|
||||
|
||||
// Prepare message data
|
||||
$options['data'] = serialize((array)$options['data']);
|
||||
|
||||
// Prepare query
|
||||
$query = "INSERT INTO {chatmessage} (" .
|
||||
"threadid, ikind, tmessage, tname, agentId, " .
|
||||
"dtmcreated, plugin, data" .
|
||||
") VALUES (" .
|
||||
":threadid, :kind, :message, :name, :agentid, " .
|
||||
":created, :plugin, :data" .
|
||||
")";
|
||||
|
||||
$values = array(
|
||||
':threadid' => $this->id,
|
||||
':kind' => $kind,
|
||||
':message' => $message,
|
||||
':name' => ($from ? $from : NULL),
|
||||
':agentid' => ($opid ? $opid : 0),
|
||||
':created' => ($time ? $time : time())
|
||||
':name' => $options['name'],
|
||||
':agentid' => $options['operator_id'],
|
||||
':created' => $options['created'],
|
||||
':plugin' => $options['plugin'],
|
||||
':data' => $options['data']
|
||||
);
|
||||
|
||||
// Execute query
|
||||
$db->query($query, $values);
|
||||
return $db->insertedId();
|
||||
}
|
||||
|
@ -326,11 +326,17 @@ class ThreadProcessor extends ClientSideProcessor {
|
||||
|
||||
// Set fields
|
||||
$kind = $args['user'] ? Thread::KIND_USER : Thread::KIND_AGENT;
|
||||
$from = $args['user'] ? $thread->userName : $thread->agentName;
|
||||
$opid = $args['user'] ? null : $operator['operatorid'];
|
||||
if ($args['user']) {
|
||||
$msg_options = array('name' => $thread->userName);
|
||||
} else {
|
||||
$msg_options = array(
|
||||
'name' => $thread->agentName,
|
||||
'operator_id' => $operator['operatorid']
|
||||
);
|
||||
}
|
||||
|
||||
// Post message
|
||||
$posted_id = $thread->postMessage($kind, $args['message'], $from, $opid);
|
||||
$posted_id = $thread->postMessage($kind, $args['message'], $msg_options);
|
||||
|
||||
// Update shownMessageId
|
||||
if($args['user'] && $thread->shownMessageId == 0) {
|
||||
@ -498,7 +504,7 @@ class ThreadProcessor extends ClientSideProcessor {
|
||||
$posted_id = $thread->postMessage(
|
||||
Thread::KIND_USER,
|
||||
$first_message,
|
||||
$visitor['name']
|
||||
array('name' => $visitor['name'])
|
||||
);
|
||||
$thread->shownMessageId = $posted_id;
|
||||
$thread->save();
|
||||
@ -621,7 +627,7 @@ class ThreadProcessor extends ClientSideProcessor {
|
||||
getstring2('chat.visitor.info', array($info))
|
||||
);
|
||||
}
|
||||
$thread->postMessage(Thread::KIND_USER, $message, $name);
|
||||
$thread->postMessage(Thread::KIND_USER, $message, array('name'=>$name));
|
||||
|
||||
// Get email for message
|
||||
$inbox_mail = get_group_email($group_id);
|
||||
|
@ -122,8 +122,10 @@ function invitation_invite($visitor_id, $operator) {
|
||||
$thread->postMessage(
|
||||
Thread::KIND_AGENT,
|
||||
getlocal("invitation.message"),
|
||||
$operator_name,
|
||||
$operator['operatorid']
|
||||
array(
|
||||
'name' => $operator_name,
|
||||
'operator_id' => $operator['operatorid']
|
||||
)
|
||||
);
|
||||
|
||||
return $thread;
|
||||
|
Loading…
Reference in New Issue
Block a user