From 1f46bd16b41b81f473328940ea2359f431de581f Mon Sep 17 00:00:00 2001 From: =?utf8?q?Tim=20D=C3=BCsterhus?= Date: Mon, 19 Apr 2021 13:42:34 +0200 Subject: [PATCH] Do not update `confirmTime` for read notifications (#4129) Co-authored-by: Matthias Schmidt --- .../UserNotificationHandler.class.php | 53 +++++++++++-------- 1 file changed, 32 insertions(+), 21 deletions(-) diff --git a/wcfsetup/install/files/lib/system/user/notification/UserNotificationHandler.class.php b/wcfsetup/install/files/lib/system/user/notification/UserNotificationHandler.class.php index f6fca466a5..fbdecf2ffa 100644 --- a/wcfsetup/install/files/lib/system/user/notification/UserNotificationHandler.class.php +++ b/wcfsetup/install/files/lib/system/user/notification/UserNotificationHandler.class.php @@ -909,6 +909,7 @@ class UserNotificationHandler extends SingletonFactory // mark as confirmed $conditions = new PreparedStatementConditionBuilder(); + $conditions->add("confirmTime = ?", [0]); $conditions->add("eventID = ?", [$event->eventID]); if (!empty($recipientIDs)) { $conditions->add("userID IN (?)", [$recipientIDs]); @@ -924,6 +925,7 @@ class UserNotificationHandler extends SingletonFactory $parameters = $conditions->getParameters(); \array_unshift($parameters, TIME_NOW); $statement->execute($parameters); + $confirmedCount = $statement->getAffectedRows(); $parameters = [ 'event' => $event, @@ -934,21 +936,23 @@ class UserNotificationHandler extends SingletonFactory ]; EventHandler::getInstance()->fireAction($this, 'markAsConfirmed', $parameters); - // delete notification_to_user assignments (mimic legacy notification system) - $sql = "DELETE FROM wcf" . WCF_N . "_user_notification_to_user - WHERE notificationID NOT IN ( - SELECT notificationID - FROM wcf" . WCF_N . "_user_notification - WHERE confirmTime = ? - )"; - $statement = WCF::getDB()->prepareStatement($sql); - $statement->execute([0]); + // Check whether anything was changed. If not, we don't need to do anything else. + if ($confirmedCount) { + // delete notification_to_user assignments (mimic legacy notification system) + $sql = "DELETE FROM wcf" . WCF_N . "_user_notification_to_user + WHERE notificationID NOT IN ( + SELECT notificationID + FROM wcf" . WCF_N . "_user_notification + WHERE confirmTime = ? + )"; + $statement = WCF::getDB()->prepareStatement($sql); + $statement->execute([0]); - // reset storage - if (!empty($recipientIDs)) { - UserStorageHandler::getInstance()->reset($recipientIDs, 'userNotificationCount'); - } else { - UserStorageHandler::getInstance()->resetAll('userNotificationCount'); + if (!empty($recipientIDs)) { + UserStorageHandler::getInstance()->reset($recipientIDs, 'userNotificationCount'); + } else { + UserStorageHandler::getInstance()->resetAll('userNotificationCount'); + } } } @@ -976,6 +980,7 @@ class UserNotificationHandler extends SingletonFactory $conditions = new PreparedStatementConditionBuilder(); $conditions->add("notificationID IN (?)", [$notificationIDs]); + $conditions->add("confirmTime = ?", [0]); // mark notifications as confirmed $sql = "UPDATE wcf" . WCF_N . "_user_notification @@ -985,18 +990,24 @@ class UserNotificationHandler extends SingletonFactory $parameters = $conditions->getParameters(); \array_unshift($parameters, TIME_NOW); $statement->execute($parameters); + $confirmedCount = $statement->getAffectedRows(); $parameters = ['notificationIDs' => $notificationIDs]; EventHandler::getInstance()->fireAction($this, 'markAsConfirmedByIDs', $parameters); - // delete notification_to_user assignments (mimic legacy notification system) - $sql = "DELETE FROM wcf" . WCF_N . "_user_notification_to_user - " . $conditions; - $statement = WCF::getDB()->prepareStatement($sql); - $statement->execute($conditions->getParameters()); + // Check whether anything was changed. If not, we don't need to do anything else. + if ($confirmedCount) { + $conditions = new PreparedStatementConditionBuilder(); + $conditions->add("notificationID IN (?)", [$notificationIDs]); - // reset user storage - UserStorageHandler::getInstance()->reset([WCF::getUser()->userID], 'userNotificationCount'); + // delete notification_to_user assignments (mimic legacy notification system) + $sql = "DELETE FROM wcf" . WCF_N . "_user_notification_to_user + " . $conditions; + $statement = WCF::getDB()->prepareStatement($sql); + $statement->execute($conditions->getParameters()); + + UserStorageHandler::getInstance()->reset([WCF::getUser()->userID], 'userNotificationCount'); + } } /** -- 2.20.1