mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-28 14:18:52 +00:00
[ticket/11413] Remove conversion of user_notifications
PHPBB3-11413
This commit is contained in:
parent
bc9b6c3b6c
commit
5edae8af1f
1 changed files with 0 additions and 90 deletions
|
@ -89,94 +89,4 @@ class phpbb_db_migration_data_310_notifications2 extends phpbb_db_migration
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update_data()
|
|
||||||
{
|
|
||||||
return array(
|
|
||||||
array('custom', array(array($this, 'convert_notifications'))),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function convert_notifications()
|
|
||||||
{
|
|
||||||
$insert_table = $this->table_prefix . 'user_notifications';
|
|
||||||
$insert_buffer = new phpbb_db_sql_insert_buffer($this->db, $insert_table);
|
|
||||||
|
|
||||||
$this->perform_conversion($insert_buffer, $insert_table);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Perform the conversion (separate for testability)
|
|
||||||
*/
|
|
||||||
public function perform_conversion($insert_buffer, $insert_table)
|
|
||||||
{
|
|
||||||
$sql = 'DELETE FROM ' . $insert_table;
|
|
||||||
$this->db->sql_query($sql);
|
|
||||||
|
|
||||||
$sql = 'SELECT user_id, user_notify_type, user_notify_pm
|
|
||||||
FROM ' . USERS_TABLE;
|
|
||||||
$result = $this->db->sql_query($sql);
|
|
||||||
|
|
||||||
while ($row = $this->db->sql_fetchrow($result))
|
|
||||||
{
|
|
||||||
$notification_methods = array();
|
|
||||||
|
|
||||||
// In-board notification
|
|
||||||
$notification_methods[] = '';
|
|
||||||
|
|
||||||
if ($row['user_notify_type'] == NOTIFY_EMAIL || $row['user_notify_type'] == NOTIFY_BOTH)
|
|
||||||
{
|
|
||||||
$notification_methods[] = 'email';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($row['user_notify_type'] == NOTIFY_IM || $row['user_notify_type'] == NOTIFY_BOTH)
|
|
||||||
{
|
|
||||||
$notification_methods[] = 'jabber';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notifications for posts
|
|
||||||
foreach (array('post', 'topic') as $item_type)
|
|
||||||
{
|
|
||||||
$this->add_method_rows(
|
|
||||||
$insert_buffer,
|
|
||||||
$item_type,
|
|
||||||
0,
|
|
||||||
$row['user_id'],
|
|
||||||
$notification_methods
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($row['user_notify_pm'])
|
|
||||||
{
|
|
||||||
// Notifications for private messages
|
|
||||||
// User either gets all methods or no method
|
|
||||||
$this->add_method_rows(
|
|
||||||
$insert_buffer,
|
|
||||||
'pm',
|
|
||||||
0,
|
|
||||||
$row['user_id'],
|
|
||||||
$notification_methods
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$this->db->sql_freeresult($result);
|
|
||||||
|
|
||||||
$insert_buffer->flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function add_method_rows(phpbb_db_sql_insert_buffer $insert_buffer, $item_type, $item_id, $user_id, array $methods)
|
|
||||||
{
|
|
||||||
$row_base = array(
|
|
||||||
'item_type' => $item_type,
|
|
||||||
'item_id' => (int) $item_id,
|
|
||||||
'user_id' => (int) $user_id,
|
|
||||||
'notify' => 1
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach ($methods as $method)
|
|
||||||
{
|
|
||||||
$row_base['method'] = $method;
|
|
||||||
$insert_buffer->insert($row_base);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue