use sql statement
This commit is contained in:
parent
829c750901
commit
ff63c5a582
@ -16,9 +16,14 @@ namespace Dotclear\Plugin\emailNotification;
|
|||||||
|
|
||||||
use cursor;
|
use cursor;
|
||||||
use dcAuth;
|
use dcAuth;
|
||||||
|
use dcBlog;
|
||||||
use dcCore;
|
use dcCore;
|
||||||
use dcNsProcess;
|
use dcNsProcess;
|
||||||
use dcRecord;
|
use dcRecord;
|
||||||
|
use Dotclear\Database\Statement\{
|
||||||
|
JoinStatement,
|
||||||
|
SelectStatement
|
||||||
|
};
|
||||||
use Dotclear\Helper\Html\Html;
|
use Dotclear\Helper\Html\Html;
|
||||||
use Dotclear\Helper\Network\Mail\Mail;
|
use Dotclear\Helper\Network\Mail\Mail;
|
||||||
use rsExtUser;
|
use rsExtUser;
|
||||||
@ -39,34 +44,57 @@ class Frontend extends dcNsProcess
|
|||||||
}
|
}
|
||||||
|
|
||||||
dcCore::app()->addBehavior('publicAfterCommentCreate', function (cursor $cur, ?int $comment_id): void {
|
dcCore::app()->addBehavior('publicAfterCommentCreate', function (cursor $cur, ?int $comment_id): void {
|
||||||
|
// nullsafe PHP < 8.0
|
||||||
|
if (is_null(dcCore::app()->auth) || is_null(dcCore::app()->blog)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
# We don't want notification for spam
|
# We don't want notification for spam
|
||||||
if ($cur->comment_status == -2) {
|
if ((int) $cur->getField('comment_status') == dcBlog::COMMENT_JUNK) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
# Information on comment author and post author
|
# Information on comment author and post author
|
||||||
$rs = dcCore::app()->auth->sudo([dcCore::app()->blog, 'getComments'], ['comment_id' => $comment_id]);
|
$rs = dcCore::app()->auth->sudo([dcCore::app()->blog, 'getComments'], ['comment_id' => $comment_id]);
|
||||||
|
if (is_null($rs) || $rs->isEmpty()) {
|
||||||
if ($rs->isEmpty()) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
# Information on blog users
|
$sql = new SelectStatement();
|
||||||
$strReq = 'SELECT U.user_id, user_email, user_options ' .
|
$users = $sql->from($sql->as(dcCore::app()->blog->prefix . dcAuth::USER_TABLE_NAME, 'U'))
|
||||||
'FROM ' . dcCore::app()->blog->prefix . dcAuth::USER_TABLE_NAME . ' U ' .
|
->columns([
|
||||||
'JOIN ' . dcCore::app()->blog->prefix . dcAuth::PERMISSIONS_TABLE_NAME . ' P ON U.user_id = P.user_id ' .
|
'U.user_id as user_id',
|
||||||
"WHERE blog_id = '" . dcCore::app()->con->escapeStr(dcCore::app()->blog->id) . "' " .
|
'user_email',
|
||||||
'UNION ' .
|
'user_options',
|
||||||
'SELECT user_id, user_email, user_options ' .
|
])
|
||||||
'FROM ' . dcCore::app()->blog->prefix . dcAuth::USER_TABLE_NAME . ' ' .
|
->join(
|
||||||
'WHERE user_super = 1 ';
|
(new JoinStatement())
|
||||||
|
->from($sql->as(dcCore::app()->blog->prefix . dcAuth::PERMISSIONS_TABLE_NAME, 'P'))
|
||||||
|
->on('U.user_id = P.user_id')
|
||||||
|
->statement()
|
||||||
|
)
|
||||||
|
->where('blog_id = ' . $sql->quote(dcCore::app()->blog->id))
|
||||||
|
->union(
|
||||||
|
(new SelectStatement())
|
||||||
|
->columns([
|
||||||
|
'U.user_id as user_id',
|
||||||
|
'user_email',
|
||||||
|
'user_options',
|
||||||
|
])
|
||||||
|
->from($sql->as(dcCore::app()->blog->prefix . dcAuth::USER_TABLE_NAME, 'U'))
|
||||||
|
->where('user_super = 1')
|
||||||
|
->statement()
|
||||||
|
)
|
||||||
|
->select();
|
||||||
|
|
||||||
$users = dcCore::app()->con->select($strReq);
|
if (is_null($users) || $users->isEmpty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
# Create notify list
|
# Create notify list
|
||||||
$ulist = [];
|
$ulist = [];
|
||||||
while ($users->fetch()) {
|
while ($users->fetch()) {
|
||||||
if (!$users->user_email) {
|
if (!$users->f('user_email')) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -75,15 +103,15 @@ class Frontend extends dcNsProcess
|
|||||||
unset($o);
|
unset($o);
|
||||||
|
|
||||||
if ($notification_pref == 'all'
|
if ($notification_pref == 'all'
|
||||||
|| ($notification_pref == 'mine' && $users->user_id == $rs->user_id)) {
|
|| ($notification_pref == 'mine' && $users->f('user_id') == $rs->f('user_id'))) {
|
||||||
$ulist[$users->user_id] = $users->user_email;
|
$ulist[$users->f('user_id')] = $users->f('user_email');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count($ulist) > 0) {
|
if (count($ulist) > 0) {
|
||||||
# Author of the post wants to be notified by mail
|
# Author of the post wants to be notified by mail
|
||||||
$headers = [
|
$headers = [
|
||||||
'Reply-To: ' . $rs->comment_email,
|
'Reply-To: ' . $rs->f('comment_email'),
|
||||||
'Content-Type: text/plain; charset=UTF-8;',
|
'Content-Type: text/plain; charset=UTF-8;',
|
||||||
'X-Mailer: Dotclear',
|
'X-Mailer: Dotclear',
|
||||||
'X-Blog-Id: ' . Mail::B64Header(dcCore::app()->blog->id),
|
'X-Blog-Id: ' . Mail::B64Header(dcCore::app()->blog->id),
|
||||||
@ -91,33 +119,33 @@ class Frontend extends dcNsProcess
|
|||||||
'X-Blog-Url: ' . Mail::B64Header(dcCore::app()->blog->url),
|
'X-Blog-Url: ' . Mail::B64Header(dcCore::app()->blog->url),
|
||||||
];
|
];
|
||||||
|
|
||||||
$subject = '[' . dcCore::app()->blog->name . '] ' . sprintf(__('"%s" - New comment'), $rs->post_title);
|
$subject = '[' . dcCore::app()->blog->name . '] ' . sprintf(__('"%s" - New comment'), $rs->f('post_title'));
|
||||||
$subject = Mail::B64Header($subject);
|
$subject = Mail::B64Header($subject);
|
||||||
|
|
||||||
$msg = preg_replace('%</p>\s*<p>%msu', "\n\n", $rs->comment_content);
|
$msg = preg_replace('%</p>\s*<p>%msu', "\n\n", $rs->f('comment_content'));
|
||||||
$msg = Html::clean($msg);
|
$msg = Html::clean($msg);
|
||||||
$msg = html_entity_decode($msg);
|
$msg = html_entity_decode($msg);
|
||||||
|
|
||||||
if ($cur->comment_status == 1) {
|
if ((int) $cur->getField('comment_status') == dcBlog::COMMENT_PUBLISHED) {
|
||||||
$status = __('published');
|
$status = __('published');
|
||||||
} elseif ($cur->comment_status == 0) {
|
} elseif ((int) $cur->getField('comment_status') == dcBlog::COMMENT_UNPUBLISHED) {
|
||||||
$status = __('unpublished');
|
$status = __('unpublished');
|
||||||
} elseif ($cur->comment_status == -1) {
|
} elseif ((int) $cur->getField('comment_status') == dcBlog::COMMENT_PENDING) {
|
||||||
$status = __('pending');
|
$status = __('pending');
|
||||||
} else {
|
} else {
|
||||||
# unknown status
|
# unknown status
|
||||||
$status = $cur->comment_status;
|
$status = $cur->getField('comment_status');
|
||||||
}
|
}
|
||||||
|
|
||||||
$msg .= "\n\n-- \n" .
|
$msg .= "\n\n-- \n" .
|
||||||
sprintf(__('Blog: %s'), dcCore::app()->blog->name) . "\n" .
|
sprintf(__('Blog: %s'), dcCore::app()->blog->name) . "\n" .
|
||||||
sprintf(__('Entry: %s <%s>'), $rs->post_title, $rs->getPostURL()) . "\n" .
|
sprintf(__('Entry: %s <%s>'), $rs->f('post_title'), $rs->getPostURL()) . "\n" .
|
||||||
sprintf(__('Comment by: %s <%s>'), $rs->comment_author, $rs->comment_email) . "\n" .
|
sprintf(__('Comment by: %s <%s>'), $rs->f('comment_author'), $rs->f('comment_email')) . "\n" .
|
||||||
sprintf(__('Website: %s'), $rs->getAuthorURL()) . "\n" .
|
sprintf(__('Website: %s'), $rs->getAuthorURL()) . "\n" .
|
||||||
sprintf(__('Comment status: %s'), $status) . "\n" .
|
sprintf(__('Comment status: %s'), $status) . "\n" .
|
||||||
sprintf(__('Edit this comment: <%s>'), DC_ADMIN_URL .
|
sprintf(__('Edit this comment: <%s>'), DC_ADMIN_URL .
|
||||||
((substr(DC_ADMIN_URL, -1) != '/') ? '/' : '') .
|
((substr(DC_ADMIN_URL, -1) != '/') ? '/' : '') .
|
||||||
'comment.php?id=' . $cur->comment_id .
|
'comment.php?id=' . $cur->getField('comment_id') .
|
||||||
'&switchblog=' . dcCore::app()->blog->id) . "\n" .
|
'&switchblog=' . dcCore::app()->blog->id) . "\n" .
|
||||||
__('You must log in on the backend before clicking on this link to go directly to the comment.');
|
__('You must log in on the backend before clicking on this link to go directly to the comment.');
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user