Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
0.00% covered (danger)
0.00%
0 / 1
50.00% covered (danger)
50.00%
2 / 4
CRAP
67.44% covered (warning)
67.44%
29 / 43
forum
0.00% covered (danger)
0.00%
0 / 1
50.00% covered (danger)
50.00%
2 / 4
11.80
67.44% covered (warning)
67.44%
29 / 43
 get_type
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
1 / 1
 find_users_for_notification
100.00% covered (success)
100.00%
1 / 1
5
100.00% covered (success)
100.00%
28 / 28
 get_email_template
0.00% covered (danger)
0.00%
0 / 1
2.00
0.00% covered (danger)
0.00%
0 / 1
 get_email_template_variables
0.00% covered (danger)
0.00%
0 / 1
6.00
0.00% covered (danger)
0.00%
0 / 13
<?php
/**
 *
 * This file is part of the phpBB Forum Software package.
 *
 * @copyright (c) phpBB Limited <https://www.phpbb.com>
 * @license GNU General Public License, version 2 (GPL-2.0)
 *
 * For full copyright and license information, please see
 * the docs/CREDITS.txt file.
 *
 */
namespace phpbb\notification\type;
/**
 * Forum notifications class
 * This class handles notifications for replies to a topic in a forum user subscribed to
 */
class forum extends \phpbb\notification\type\post
{
    /**
     * Get notification type name
     *
     * @return string
     */
    public function get_type()
    {
        return 'notification.type.forum';
    }
    /**
     * Notification option data (for outputting to the user)
     *
     * @var bool|array False if the service should use its default data
     *                     Array of data (including keys 'id', 'lang', and 'group')
     */
    static public $notification_option = [
        'lang'    => 'NOTIFICATION_TYPE_FORUM',
        'group'    => 'NOTIFICATION_GROUP_POSTING',
    ];
    /**
     * Find the users who want to receive notifications
     *
     * @param array $post Data from submit_post
     * @param array $options Options for finding users for notification
     *
     * @return array
     */
    public function find_users_for_notification($post, $options = [])
    {
        $options = array_merge([
            'ignore_users'        => [],
        ], $options);
        $users = [];
        $sql = 'SELECT user_id
            FROM ' . FORUMS_WATCH_TABLE . '
            WHERE forum_id = ' . (int) $post['forum_id'] . '
                AND notify_status = ' . NOTIFY_YES . '
                AND user_id <> ' . (int) $post['poster_id'];
        $result = $this->db->sql_query($sql);
        while ($row = $this->db->sql_fetchrow($result))
        {
            $users[] = (int) $row['user_id'];
        }
        $this->db->sql_freeresult($result);
        $notify_users = $this->get_authorised_recipients($users, $post['forum_id'], $options, true);
        if (empty($notify_users))
        {
            return [];
        }
        // Try to find the users who already have been notified about replies and have not read them
        // Just update their notifications
        $notified_users = $this->notification_manager->get_notified_users($this->get_type(), [
            'item_parent_id'    => static::get_item_parent_id($post),
            'read'                => 0,
        ]);
        foreach ($notified_users as $user => $notification_data)
        {
            unset($notify_users[$user]);
            /** @var post $notification */
            $notification = $this->notification_manager->get_item_type_class($this->get_type(), $notification_data);
            $update_responders = $notification->add_responders($post);
            if (!empty($update_responders))
            {
                $this->notification_manager->update_notification($notification, $update_responders, [
                    'item_parent_id'    => self::get_item_parent_id($post),
                    'read'                => 0,
                    'user_id'            => $user,
                ]);
            }
        }
        return $notify_users;
    }
    /**
     * Get email template
     *
     * @return string|bool
     */
    public function get_email_template()
    {
        return 'forum_notify';
    }
    /**
     * Get email template variables
     *
     * @return array
     */
    public function get_email_template_variables()
    {
        if ($this->get_data('post_username'))
        {
            $username = $this->get_data('post_username');
        }
        else
        {
            $username = $this->user_loader->get_username($this->get_data('poster_id'), 'username');
        }
        return [
            'AUTHOR_NAME'                => html_entity_decode($username, ENT_COMPAT),
            'FORUM_NAME'                => html_entity_decode(censor_text($this->get_data('forum_name')), ENT_COMPAT),
            'POST_SUBJECT'                => html_entity_decode(censor_text($this->get_data('post_subject')), ENT_COMPAT),
            'TOPIC_TITLE'                => html_entity_decode(censor_text($this->get_data('topic_title')), ENT_COMPAT),
            'U_VIEW_POST'                => generate_board_url() . "/viewtopic.{$this->php_ext}?p={$this->item_id}#p{$this->item_id}",
            'U_NEWEST_POST'                => generate_board_url() . "/viewtopic.{$this->php_ext}?t={$this->item_parent_id}&e=1&view=unread#unread",
            'U_TOPIC'                    => generate_board_url() . "/viewtopic.{$this->php_ext}?t={$this->item_parent_id}",
            'U_VIEW_TOPIC'                => generate_board_url() . "/viewtopic.{$this->php_ext}?t={$this->item_parent_id}",
            'U_FORUM'                    => generate_board_url() . "/viewforum.{$this->php_ext}?f={$this->get_data('forum_id')}",
            'U_STOP_WATCHING_FORUM'        => generate_board_url() . "/viewforum.{$this->php_ext}?uid={$this->user_id}&f={$this->get_data('forum_id')}&unwatch=forum",
        ];
    }
}