mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-07 20:08:53 +00:00
Merge branch '3.2.x'
This commit is contained in:
commit
11dfe7f18e
2 changed files with 10 additions and 23 deletions
|
@ -899,32 +899,19 @@ class manager
|
|||
*/
|
||||
public function get_notification_type_id($notification_type_name)
|
||||
{
|
||||
$notification_type_ids = $this->cache->get('notification_type_ids');
|
||||
|
||||
$this->db->sql_transaction('begin');
|
||||
|
||||
if ($notification_type_ids === false)
|
||||
$sql = 'SELECT notification_type_id, notification_type_name
|
||||
FROM ' . $this->notification_types_table;
|
||||
$result = $this->db->sql_query($sql, 604800); // cache for one week
|
||||
while ($row = $this->db->sql_fetchrow($result))
|
||||
{
|
||||
$notification_type_ids = array();
|
||||
|
||||
$sql = 'SELECT notification_type_id, notification_type_name
|
||||
FROM ' . $this->notification_types_table;
|
||||
$result = $this->db->sql_query($sql);
|
||||
while ($row = $this->db->sql_fetchrow($result))
|
||||
{
|
||||
$notification_type_ids[$row['notification_type_name']] = (int) $row['notification_type_id'];
|
||||
}
|
||||
$this->db->sql_freeresult($result);
|
||||
|
||||
$this->cache->put('notification_type_ids', $notification_type_ids);
|
||||
$notification_type_ids[$row['notification_type_name']] = (int) $row['notification_type_id'];
|
||||
}
|
||||
$this->db->sql_freeresult($result);
|
||||
|
||||
if (!isset($notification_type_ids[$notification_type_name]))
|
||||
{
|
||||
if (!isset($this->notification_types[$notification_type_name]) && !isset($this->notification_types['notification.type.' . $notification_type_name]))
|
||||
{
|
||||
$this->db->sql_transaction('rollback');
|
||||
|
||||
throw new \phpbb\notification\exception('NOTIFICATION_TYPE_NOT_EXIST', array($notification_type_name));
|
||||
}
|
||||
|
||||
|
@ -934,13 +921,13 @@ class manager
|
|||
));
|
||||
$this->db->sql_query($sql);
|
||||
|
||||
// expose new notification type ID for this request
|
||||
$notification_type_ids[$notification_type_name] = (int) $this->db->sql_nextid();
|
||||
|
||||
$this->cache->put('notification_type_ids', $notification_type_ids);
|
||||
// destroy cache, we have a new addition which we have to to load next time
|
||||
$this->cache->destroy('sql', $this->notification_types_table);
|
||||
}
|
||||
|
||||
$this->db->sql_transaction('commit');
|
||||
|
||||
return $notification_type_ids[$notification_type_name];
|
||||
}
|
||||
|
||||
|
|
|
@ -394,6 +394,6 @@ class board extends \phpbb\notification\method\base
|
|||
WHERE notification_type_id = ' . (int) $notification_type_id;
|
||||
$this->db->sql_query($sql);
|
||||
|
||||
$this->cache->destroy('notification_type_ids');
|
||||
$this->cache->destroy('sql', $this->notification_types_table);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue