From ebb37dd8a1b573d3f9ae367e202c3cfc7541d5a3 Mon Sep 17 00:00:00 2001 From: Christian Wach <needle@haystack.co.uk> Date: Wed, 11 Sep 2019 13:18:52 +0100 Subject: [PATCH] Restrict inactive Dashlet query to Dashlets in the current domain Signed-off-by: Kevin Cristiano <kcristiano@kcristiano.com> --- civicrm/CRM/Core/BAO/Dashboard.php | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/civicrm/CRM/Core/BAO/Dashboard.php b/civicrm/CRM/Core/BAO/Dashboard.php index 2c89838c40..4569b27f95 100644 --- a/civicrm/CRM/Core/BAO/Dashboard.php +++ b/civicrm/CRM/Core/BAO/Dashboard.php @@ -357,11 +357,30 @@ class CRM_Core_BAO_Dashboard extends CRM_Core_DAO_Dashboard { } } - // Disable inactive widgets + // Find dashlets in this domain. + $domainDashlets = civicrm_api3('Dashboard', 'get', [ + 'return' => array('id'), + 'domain_id' => CRM_Core_Config::domainID(), + ]); + + // Get the array of IDs. + $domainDashletIDs = []; + if ($domainDashlets['is_error'] == 0) { + foreach ($domainDashlets['values'] as $domainDashlet) { + $domainDashletIDs[] = $domainDashlet['id']; + } + } + + // Restrict query to Dashlets in this domain. + $domainDashletClause = !empty($domainDashletIDs) ? "dashboard_id IN (" . implode(',', $domainDashletIDs) . ")" : '(1)'; + + // Disable inactive widgets. $dashletClause = $dashletIDs ? "dashboard_id NOT IN (" . implode(',', $dashletIDs) . ")" : '(1)'; $updateQuery = "UPDATE civicrm_dashboard_contact SET is_active = 0 - WHERE $dashletClause AND contact_id = {$contactID}"; + WHERE $domainDashletClause + AND $dashletClause + AND contact_id = {$contactID}"; CRM_Core_DAO::executeQuery($updateQuery); } -- GitLab