1
0
mirror of https://github.com/phpbb/phpbb.git synced 2025-10-04 19:51:39 +02:00
Files
php-phpbb/phpBB/phpbb/db/migration/data/v310/notifications_board.php
Nicofuma be0d4e20d4 [ticket/11444] Moving the in-board notifications to a method class
Currently the in-board method for the notifications is hardcoded and
cannot be disabled. This method should be in his own class extending
`phpbb\notification\method\method_interface`.

It also add the possibility, for each method, to be enabled by default (ie:
no entry in the DB => notification enabled).

https://tracker.phpbb.com/browse/PHPBB3-11444
https://tracker.phpbb.com/browse/PHPBB3-11967

PHPBB3-11444
2015-07-13 22:41:13 +02:00

74 lines
1.7 KiB
PHP

<?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\db\migration\data\v310;
class notifications_board extends \phpbb\db\migration\migration
{
static public function depends_on()
{
return array('\phpbb\db\migration\data\v310\notifications');
}
public function update_data()
{
return array(
array('config.add', array('allow_board_notifications', 1)),
array('custom', array(array($this, 'update_user_subscriptions'))),
array('custom', array(array($this, 'update_module'))),
);
}
public function update_module()
{
$sql = 'UPDATE ' . MODULES_TABLE . "
SET auth = 'cfg_allow_board_notifications'
WHERE module_basename = 'ucp_notifications'
AND module_mode = 'notification_list'";
$this->sql_query($sql);
}
public function update_user_subscriptions()
{
$sql = 'UPDATE ' . USER_NOTIFICATIONS_TABLE . "
SET method = 'notification.method.board'
WHERE method = ''";
$this->sql_query($sql);
}
public function revert_data()
{
return array(
array('custom', array(array($this, 'revert_user_subscriptions'))),
array('custom', array(array($this, 'revert_module'))),
);
}
public function revert_user_subscriptions()
{
$sql = 'UPDATE ' . USER_NOTIFICATIONS_TABLE . "
SET method = ''
WHERE method = 'notification.method.board'";
$this->sql_query($sql);
}
public function revert_module()
{
$sql = 'UPDATE ' . MODULES_TABLE . "
SET auth = ''
WHERE module_basename = 'ucp_notifications'
AND module_mode = 'notification_list'";
$this->sql_query($sql);
}
}