Merge pull request #48 from abinoam/thmail-5
Comment Notifications by Email - Threading Them
This commit is contained in:
commit
896f97b31a
6 changed files with 101 additions and 13 deletions
2
boot.php
2
boot.php
|
@ -11,7 +11,7 @@ require_once('include/cache.php');
|
||||||
define ( 'FRIENDICA_PLATFORM', 'Friendica');
|
define ( 'FRIENDICA_PLATFORM', 'Friendica');
|
||||||
define ( 'FRIENDICA_VERSION', '2.3.1263' );
|
define ( 'FRIENDICA_VERSION', '2.3.1263' );
|
||||||
define ( 'DFRN_PROTOCOL_VERSION', '2.22' );
|
define ( 'DFRN_PROTOCOL_VERSION', '2.22' );
|
||||||
define ( 'DB_UPDATE_VERSION', 1125 );
|
define ( 'DB_UPDATE_VERSION', 1126 );
|
||||||
|
|
||||||
define ( 'EOL', "<br />\r\n" );
|
define ( 'EOL', "<br />\r\n" );
|
||||||
define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
|
define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
|
||||||
|
|
26
database.sql
26
database.sql
|
@ -810,5 +810,31 @@ INDEX ( `uid` )
|
||||||
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Table structure for table `notify-threads`
|
||||||
|
--
|
||||||
|
-- notify-id: notify.id of the first notification of this thread
|
||||||
|
-- master-parent-item: item.id of the parent item
|
||||||
|
-- parent-item: item.id of the imediate parent (only for multi-thread)
|
||||||
|
-- not used yet.
|
||||||
|
-- receiver-uid: user.uid of the receiver of this notification.
|
||||||
|
--
|
||||||
|
-- If we query for a master-parent-item and receiver-uid...
|
||||||
|
-- * Returns 1 item: this is not the parent notification,
|
||||||
|
-- so just "follow" the thread (references to this notification)
|
||||||
|
-- * Returns no item: this is the first notification related to
|
||||||
|
-- this parent item. So, create the record and use the message-id
|
||||||
|
-- header.
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `notify-threads` (
|
||||||
|
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
|
||||||
|
`notify-id` INT NOT NULL,
|
||||||
|
`master-parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
|
||||||
|
`parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
|
||||||
|
`receiver-uid` INT NOT NULL,
|
||||||
|
INDEX ( `master-parent-item` ),
|
||||||
|
INDEX ( `receiver-uid` )
|
||||||
|
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,9 @@ function notification($params) {
|
||||||
$site_admin = sprintf( t('%s Administrator'), $sitename);
|
$site_admin = sprintf( t('%s Administrator'), $sitename);
|
||||||
|
|
||||||
$sender_name = $product;
|
$sender_name = $product;
|
||||||
$sender_email = t('noreply') . '@' . $a->get_hostname();
|
$hostname = $a->get_hostname();
|
||||||
|
$sender_email = t('noreply') . '@' . $hostname;
|
||||||
|
$additional_mail_header = "";
|
||||||
|
|
||||||
if(array_key_exists('item',$params)) {
|
if(array_key_exists('item',$params)) {
|
||||||
$title = $params['item']['title'];
|
$title = $params['item']['title'];
|
||||||
|
@ -36,8 +38,15 @@ function notification($params) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if($params['type'] == NOTIFY_COMMENT) {
|
if($params['type'] == NOTIFY_COMMENT) {
|
||||||
|
logger("notification: params = " . print_r($params, true), LOGGER_DEBUG);
|
||||||
|
|
||||||
$subject = sprintf( t('%s commented on an item at %s'), $params['source_name'], $sitename);
|
$parent_id = $params['parent'];
|
||||||
|
|
||||||
|
// Some mail softwares relies on subject field for threading.
|
||||||
|
// So, we cannot have different subjects for notifications of the same thread.
|
||||||
|
// Before this we have the name of the replier on the subject rendering
|
||||||
|
// differents subjects for messages on the same thread.
|
||||||
|
$subject = sprintf( t('Someone commented on item #%d at %s'), $parent_id, $sitename);
|
||||||
$preamble = sprintf( t('%s commented on an item/conversation you have been following.'), $params['source_name']);
|
$preamble = sprintf( t('%s commented on an item/conversation you have been following.'), $params['source_name']);
|
||||||
$epreamble = sprintf( t('%s commented in %s.'), '[url=' . $params['source_link'] . ']' . $params['source_name'] . '[/url]', '[url=$itemlink]' . t('a watched conversation') . '[/url]');
|
$epreamble = sprintf( t('%s commented in %s.'), '[url=' . $params['source_link'] . ']' . $params['source_name'] . '[/url]', '[url=$itemlink]' . t('a watched conversation') . '[/url]');
|
||||||
|
|
||||||
|
@ -126,8 +135,6 @@ function notification($params) {
|
||||||
} while($dups == true);
|
} while($dups == true);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// create notification entry in DB
|
// create notification entry in DB
|
||||||
|
|
||||||
$r = q("insert into notify (hash,name,url,photo,date,uid,link,type,verb,otype)
|
$r = q("insert into notify (hash,name,url,photo,date,uid,link,type,verb,otype)
|
||||||
|
@ -170,6 +177,40 @@ function notification($params) {
|
||||||
|
|
||||||
logger('notification: sending notification email');
|
logger('notification: sending notification email');
|
||||||
|
|
||||||
|
$id_for_parent = "${params['parent']}@${hostname}";
|
||||||
|
|
||||||
|
// Is this the first email notification for this parent item and user?
|
||||||
|
|
||||||
|
$r = q("select `id` from `notify-threads` where `master-parent-item` = %d and `receiver-uid` = %d limit 1",
|
||||||
|
intval($params['parent']),
|
||||||
|
intval($params['uid']) );
|
||||||
|
|
||||||
|
// If so, create the record of it and use a message-id smtp header.
|
||||||
|
|
||||||
|
if(!$r) {
|
||||||
|
logger("norify_id:" . intval($notify_id). ", parent: " . intval($params['parent']) . "uid: " .
|
||||||
|
intval($params['uid']), LOGGER_DEBUG);
|
||||||
|
$r = q("insert into `notify-threads` (`notify-id`, `master-parent-item`, `receiver-uid`, `parent-item`)
|
||||||
|
values(%d,%d,%d,%d)",
|
||||||
|
intval($notify_id),
|
||||||
|
intval($params['parent']),
|
||||||
|
intval($params['uid']),
|
||||||
|
0 );
|
||||||
|
|
||||||
|
$additional_mail_header .= "Message-ID: <${id_for_parent}>\n";
|
||||||
|
$log_msg = "include/enotify: No previous notification found for this parent:\n" .
|
||||||
|
" parent: ${params['parent']}\n" . " uid : ${params['uid']}\n";
|
||||||
|
logger($log_msg, LOGGER_DEBUG);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If not, just "follow" the thread.
|
||||||
|
|
||||||
|
else {
|
||||||
|
$additional_mail_header = "References: <${id_for_parent}>\nIn-Reply-To: <${id_for_parent}>\n";
|
||||||
|
logger("include/enotify: There's already a notification for this parent:\n" . print_r($r, true), LOGGER_DEBUG);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$textversion = strip_tags(html_entity_decode(bbcode(stripslashes(str_replace(array("\\r\\n", "\\r", "\\n"), "\n",
|
$textversion = strip_tags(html_entity_decode(bbcode(stripslashes(str_replace(array("\\r\\n", "\\r", "\\n"), "\n",
|
||||||
$body))),ENT_QUOTES,'UTF-8'));
|
$body))),ENT_QUOTES,'UTF-8'));
|
||||||
|
@ -227,7 +268,8 @@ function notification($params) {
|
||||||
'toEmail' => $params['to_email'],
|
'toEmail' => $params['to_email'],
|
||||||
'messageSubject' => $subject,
|
'messageSubject' => $subject,
|
||||||
'htmlVersion' => $email_html_body,
|
'htmlVersion' => $email_html_body,
|
||||||
'textVersion' => $email_text_body
|
'textVersion' => $email_text_body,
|
||||||
|
'additionalMailHeader' => $additional_mail_header,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -248,6 +290,7 @@ class enotify {
|
||||||
* @param messageSubject subject of the message
|
* @param messageSubject subject of the message
|
||||||
* @param htmlVersion html version of the message
|
* @param htmlVersion html version of the message
|
||||||
* @param textVersion text only version of the message
|
* @param textVersion text only version of the message
|
||||||
|
* @param additionalMailHeader additions to the smtp mail header
|
||||||
*/
|
*/
|
||||||
static public function send($params) {
|
static public function send($params) {
|
||||||
|
|
||||||
|
@ -262,6 +305,7 @@ class enotify {
|
||||||
|
|
||||||
// generate a multipart/alternative message header
|
// generate a multipart/alternative message header
|
||||||
$messageHeader =
|
$messageHeader =
|
||||||
|
$params['additionalMailHeader'] .
|
||||||
"From: {$params['fromName']} <{$params['fromEmail']}>\n" .
|
"From: {$params['fromName']} <{$params['fromEmail']}>\n" .
|
||||||
"Reply-To: {$params['fromName']} <{$params['replyTo']}>\n" .
|
"Reply-To: {$params['fromName']} <{$params['replyTo']}>\n" .
|
||||||
"MIME-Version: 1.0\n" .
|
"MIME-Version: 1.0\n" .
|
||||||
|
|
|
@ -2223,7 +2223,8 @@ function local_delivery($importer,$data) {
|
||||||
'source_photo' => ((link_compare($datarray['author-link'],$importer['url']))
|
'source_photo' => ((link_compare($datarray['author-link'],$importer['url']))
|
||||||
? $importer['thumb'] : $datarray['author-avatar']),
|
? $importer['thumb'] : $datarray['author-avatar']),
|
||||||
'verb' => ACTIVITY_POST,
|
'verb' => ACTIVITY_POST,
|
||||||
'otype' => 'item'
|
'otype' => 'item',
|
||||||
|
'parent' => $parent,
|
||||||
|
|
||||||
));
|
));
|
||||||
|
|
||||||
|
@ -2317,7 +2318,7 @@ function local_delivery($importer,$data) {
|
||||||
|
|
||||||
if($datarray['type'] != 'activity') {
|
if($datarray['type'] != 'activity') {
|
||||||
|
|
||||||
$myconv = q("SELECT `author-link`, `author-avatar` FROM `item` WHERE `parent-uri` = '%s' AND `uid` = %d AND `parent` != 0 ",
|
$myconv = q("SELECT `author-link`, `author-avatar`, `parent` FROM `item` WHERE `parent-uri` = '%s' AND `uid` = %d AND `parent` != 0 ",
|
||||||
dbesc($parent_uri),
|
dbesc($parent_uri),
|
||||||
intval($importer['importer_uid'])
|
intval($importer['importer_uid'])
|
||||||
);
|
);
|
||||||
|
@ -2331,6 +2332,8 @@ function local_delivery($importer,$data) {
|
||||||
|
|
||||||
require_once('include/enotify.php');
|
require_once('include/enotify.php');
|
||||||
|
|
||||||
|
$conv_parent = $conv['parent'];
|
||||||
|
|
||||||
notification(array(
|
notification(array(
|
||||||
'type' => NOTIFY_COMMENT,
|
'type' => NOTIFY_COMMENT,
|
||||||
'notify_flags' => $importer['notify-flags'],
|
'notify_flags' => $importer['notify-flags'],
|
||||||
|
@ -2345,7 +2348,8 @@ function local_delivery($importer,$data) {
|
||||||
'source_photo' => ((link_compare($datarray['author-link'],$importer['url']))
|
'source_photo' => ((link_compare($datarray['author-link'],$importer['url']))
|
||||||
? $importer['thumb'] : $datarray['author-avatar']),
|
? $importer['thumb'] : $datarray['author-avatar']),
|
||||||
'verb' => ACTIVITY_POST,
|
'verb' => ACTIVITY_POST,
|
||||||
'otype' => 'item'
|
'otype' => 'item',
|
||||||
|
'parent' => $conv_parent,
|
||||||
|
|
||||||
));
|
));
|
||||||
|
|
||||||
|
|
|
@ -755,7 +755,8 @@ function item_post(&$a) {
|
||||||
'source_link' => $datarray['author-link'],
|
'source_link' => $datarray['author-link'],
|
||||||
'source_photo' => $datarray['author-avatar'],
|
'source_photo' => $datarray['author-avatar'],
|
||||||
'verb' => ACTIVITY_POST,
|
'verb' => ACTIVITY_POST,
|
||||||
'otype' => 'item'
|
'otype' => 'item',
|
||||||
|
'parent' => $parent,
|
||||||
));
|
));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
15
update.php
15
update.php
|
@ -1,6 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
define( 'UPDATE_VERSION' , 1125 );
|
define( 'UPDATE_VERSION' , 1126 );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -1077,3 +1077,16 @@ set_config('system','allowed_themes','dispy,quattro,testbubble,vier,darkbubble,d
|
||||||
function update_1124() {
|
function update_1124() {
|
||||||
q("alter table item add index (`author-name`) ");
|
q("alter table item add index (`author-name`) ");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function update_1125() {
|
||||||
|
q("CREATE TABLE IF NOT EXISTS `notify-threads` (
|
||||||
|
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
|
||||||
|
`notify-id` INT NOT NULL,
|
||||||
|
`master-parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
|
||||||
|
`parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
|
||||||
|
`receiver-uid` INT NOT NULL,
|
||||||
|
INDEX ( `master-parent-item` ),
|
||||||
|
INDEX ( `receiver-uid` )
|
||||||
|
) ENGINE = MyISAM DEFAULT CHARSET=utf8");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue