diff options
author | Haakon Meland Eriksen <haakon.eriksen@far.no> | 2015-10-01 17:31:22 +0200 |
---|---|---|
committer | Haakon Meland Eriksen <haakon.eriksen@far.no> | 2015-10-01 17:31:22 +0200 |
commit | 2696cf9b9eb84e52532f783cfcab6e4264d53c76 (patch) | |
tree | 7eaa74544a790e18144d9d06f123050775714a93 /mod/dreport.php | |
parent | e07ff7d3fbb9bef720831dc71470b70a882abfdf (diff) | |
parent | d9f962ee6ff086da4c7b2d5959802397cb072ef2 (diff) | |
download | volse-hubzilla-2696cf9b9eb84e52532f783cfcab6e4264d53c76.tar.gz volse-hubzilla-2696cf9b9eb84e52532f783cfcab6e4264d53c76.tar.bz2 volse-hubzilla-2696cf9b9eb84e52532f783cfcab6e4264d53c76.zip |
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'mod/dreport.php')
-rw-r--r-- | mod/dreport.php | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/mod/dreport.php b/mod/dreport.php index 31a6274c8..c320bf0e6 100644 --- a/mod/dreport.php +++ b/mod/dreport.php @@ -7,14 +7,44 @@ function dreport_content(&$a) { return; } + $table = 'item'; + $channel = $a->get_channel(); $mid = ((argc() > 1) ? argv(1) : ''); + if($mid === 'mail') { + $table = 'mail'; + $mid = ((argc() > 2) ? argv(2) : ''); + } + + if(! $mid) { notice( t('Invalid message') . EOL); return; } + + switch($table) { + case 'item': + $i = q("select id from item where mid = '%s' and author_xchan = '%s' ", + dbesc($mid), + dbesc($channel['channel_hash']) + ); + break; + case 'mail': + $i = q("select id from mail where mid = '%s' and from_xchan = '%s'", + dbesc($mid), + dbesc($channel['channel_hash']) + ); + break; + default: + break; + } + + if(! $i) { + notice( t('Permission denied') . EOL); + return; + } $r = q("select * from dreport where dreport_xchan = '%s' and dreport_mid = '%s'", dbesc($channel['channel_hash']), @@ -33,6 +63,11 @@ function dreport_content(&$a) { for($x = 0; $x < count($r); $x++ ) { $r[$x]['name'] = escape_tags(substr($r[$x]['dreport_recip'],strpos($r[$x]['dreport_recip'],' '))); + // This has two purposes: 1. make the delivery report strings translateable, and + // 2. assign an ordering to item delivery results so we can group them and provide + // a readable report with more interesting events listed toward the top and lesser + // interesting items towards the bottom + switch($r[$x]['dreport_result']) { case 'channel sync processed': $r[$x]['gravity'] = 0; @@ -61,6 +96,18 @@ function dreport_content(&$a) { $r[$x]['dreport_result'] = t('permission denied'); $r[$x]['gravity'] = 6; break; + case 'recipient not found': + $r[$x]['dreport_result'] = t('recipient not found'); + break; + case 'mail recalled': + $r[$x]['dreport_result'] = t('mail recalled'); + break; + case 'duplicate mail received': + $r[$x]['dreport_result'] = t('duplicate mail received'); + break; + case 'mail delivered': + $r[$x]['dreport_result'] = t('mail delivered'); + break; default: $r[$x]['gravity'] = 1; break; |