1
0
mirror of https://github.com/phpbb/phpbb.git synced 2025-07-31 14:00:31 +02:00

[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
This commit is contained in:
Nicofuma
2014-04-28 14:00:27 +02:00
committed by Tristan Darricau
parent 58d1d37c16
commit be0d4e20d4
55 changed files with 1229 additions and 609 deletions

View File

@@ -0,0 +1,73 @@
<?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);
}
}