From e1a3313660cededa625c64c8eae9c7170dd1ed9e Mon Sep 17 00:00:00 2001 From: Evangelos Foutras Date: Mon, 20 May 2019 18:08:45 +0300 Subject: [PATCH] [Web] Fix showing domain with disabled sender check If a mailbox is allowed to send as any address under its domain (+ alias domains) and the domain itself has no aliases configured, no information about this fact is shown to the user. That is to say, the "Do not check sender access for the following domain(s) and its alias domains" field under mailbox details is empty. The above is happening because the second GROUP_CONCAT() returns NULL making the enclosing CONCAT() return NULL as well. Fix this by using CONCAT_WS() which correctly handles the case of zero domain aliases. Furthermore, move the IFNULL() to the first GROUP_CONCAT() because CONCAT_WS() returns an empty string when both GROUP_CONCAT()'s are NULL. We can be certain that when the first GROUP_CONCAT() is NULL the second one will be as well, so it's safe to use IFNULL() there. --- data/web/inc/functions.inc.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/data/web/inc/functions.inc.php b/data/web/inc/functions.inc.php index ebce58196..e5f4f788e 100644 --- a/data/web/inc/functions.inc.php +++ b/data/web/inc/functions.inc.php @@ -676,7 +676,7 @@ function user_get_alias_details($username) { while ($row = array_shift($run)) { $data['aliases_also_send_as'] = $row['send_as']; } - $stmt = $pdo->prepare("SELECT IFNULL(CONCAT(GROUP_CONCAT(DISTINCT `send_as` SEPARATOR ', '), ', ', GROUP_CONCAT(DISTINCT CONCAT('@',`alias_domain`) SEPARATOR ', ')), '✘') AS `send_as` FROM `sender_acl` LEFT JOIN `alias_domain` ON `alias_domain`.`target_domain` = TRIM(LEADING '@' FROM `send_as`) WHERE `logged_in_as` = :username AND `send_as` LIKE '@%';"); + $stmt = $pdo->prepare("SELECT CONCAT_WS(', ', IFNULL(GROUP_CONCAT(DISTINCT `send_as` SEPARATOR ', '), '✘'), GROUP_CONCAT(DISTINCT CONCAT('@',`alias_domain`) SEPARATOR ', ')) AS `send_as` FROM `sender_acl` LEFT JOIN `alias_domain` ON `alias_domain`.`target_domain` = TRIM(LEADING '@' FROM `send_as`) WHERE `logged_in_as` = :username AND `send_as` LIKE '@%';"); $stmt->execute(array(':username' => $username)); $run = $stmt->fetchAll(PDO::FETCH_ASSOC); while ($row = array_shift($run)) {