mirror of
https://github.com/phpbb/phpbb.git
synced 2025-07-30 21:40:43 +02:00
[ticket/11103] General notification email template.
PHPBB3-11103
This commit is contained in:
@@ -83,19 +83,8 @@ abstract class phpbb_notifications_method_base implements phpbb_notifications_me
|
||||
}
|
||||
|
||||
/**
|
||||
* Basic run queue function.
|
||||
* Child methods should override this function if there are more efficient methods to mass-notification
|
||||
* Empty the queue
|
||||
*/
|
||||
public function run_queue()
|
||||
{
|
||||
foreach ($this->queue as $notification)
|
||||
{
|
||||
$this->notify($notification);
|
||||
}
|
||||
|
||||
$this->empty_queue();
|
||||
}
|
||||
|
||||
protected function empty_queue()
|
||||
{
|
||||
$this->queue = array();
|
||||
|
@@ -33,12 +33,7 @@ class phpbb_notifications_method_email extends phpbb_notifications_method_base
|
||||
return true;
|
||||
}
|
||||
|
||||
public function notify($notification)
|
||||
{
|
||||
// email the user
|
||||
}
|
||||
|
||||
public function run_queue()
|
||||
public function notify()
|
||||
{
|
||||
if (!sizeof($this->queue))
|
||||
{
|
||||
@@ -80,14 +75,18 @@ class phpbb_notifications_method_email extends phpbb_notifications_method_base
|
||||
|
||||
$user = $this->service->get_user($notification->user_id);
|
||||
|
||||
$messenger->template('privmsg_notify', $user['user_lang']);
|
||||
$messenger->template('notification', $user['user_lang']);
|
||||
|
||||
$messenger->to($user['user_email'], $user['username']);
|
||||
|
||||
$messenger->assign_vars(array(
|
||||
'SUBJECT' => htmlspecialchars_decode($notification->get_title()),
|
||||
'USERNAME' => $user['username'],
|
||||
|
||||
'MESSAGE' => htmlspecialchars_decode($notification->get_title()),
|
||||
|
||||
'U_VIEW_MESSAGE' => $notification->get_full_url(),
|
||||
|
||||
'U_UNSUBSCRIBE' => $notification->get_unsubscribe_url(),
|
||||
));
|
||||
|
||||
$messenger->send('email');
|
||||
|
@@ -21,5 +21,5 @@ if (!defined('IN_PHPBB'))
|
||||
*/
|
||||
interface phpbb_notifications_method_interface
|
||||
{
|
||||
public function notify($notification);
|
||||
public function notify();
|
||||
}
|
||||
|
@@ -169,7 +169,7 @@ class phpbb_notifications_service
|
||||
// run the queue for each method to send notifications
|
||||
foreach ($notification_methods as $method)
|
||||
{
|
||||
$method->run_queue();
|
||||
$method->notify();
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -120,7 +120,7 @@ abstract class phpbb_notifications_type_base implements phpbb_notifications_type
|
||||
), $options);
|
||||
|
||||
$template->assign_block_vars($options['template_block'], array(
|
||||
'TITLE' => $this->get_title(),
|
||||
'TITLE' => $this->get_formatted_title(),
|
||||
'URL' => $this->get_url(),
|
||||
'TIME' => $user->format_date($this->time),
|
||||
|
||||
@@ -173,4 +173,24 @@ abstract class phpbb_notifications_type_base implements phpbb_notifications_type
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the formatted title of this notification (fall-back)
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function get_formatted_title()
|
||||
{
|
||||
return $this->get_title();
|
||||
}
|
||||
|
||||
/**
|
||||
* URL to unsubscribe to this notification
|
||||
*
|
||||
* @param string|bool $method Method name to unsubscribe from (email|jabber|etc), False to unsubscribe from all notifications for this item
|
||||
*/
|
||||
public function get_unsubscribe_url($method = false)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
@@ -29,9 +29,13 @@ interface phpbb_notifications_type_interface
|
||||
|
||||
public function get_title();
|
||||
|
||||
public function get_formatted_title();
|
||||
|
||||
public function get_url();
|
||||
|
||||
public function get_full_url();
|
||||
|
||||
public function get_unsubscribe_url($method);
|
||||
|
||||
public function create_insert_array($type_data);
|
||||
}
|
||||
|
@@ -89,7 +89,21 @@ class phpbb_notifications_type_pm extends phpbb_notifications_type_base
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the title of this notification
|
||||
* Get the HTML formatted title of this notification
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function get_formatted_title()
|
||||
{
|
||||
$user_data = $this->service->get_user($this->get_data('from_user_id'));
|
||||
|
||||
$username = get_username_string('no_profile', $user_data['user_id'], $user_data['username'], $user_data['user_colour']);
|
||||
|
||||
return $username . ' sent you a private message titled: ' . $this->get_data('message_subject');
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the plain text title of this notification
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
@@ -97,9 +111,7 @@ class phpbb_notifications_type_pm extends phpbb_notifications_type_base
|
||||
{
|
||||
$user_data = $this->service->get_user($this->get_data('from_user_id'));
|
||||
|
||||
$username = get_username_string('no_profile', $user_data['user_id'], $user_data['username'], $user_data['user_colour']);
|
||||
|
||||
return $username . ' sent you a private message titled: ' . $this->get_data('message_subject');
|
||||
return $user_data['username'] . ' sent you a private message titled: ' . $this->get_data('message_subject');
|
||||
}
|
||||
|
||||
/**
|
||||
|
Reference in New Issue
Block a user