diff --git a/CRM/Core/BAO/Log.php b/CRM/Core/BAO/Log.php index e6e83aac4da5..36f56e1a5133 100644 --- a/CRM/Core/BAO/Log.php +++ b/CRM/Core/BAO/Log.php @@ -161,28 +161,22 @@ public static function getContactLogCount($contactID) { * @return int|FALSE * report id of Contact Logging Report (Summary) */ - public static function useLoggingReport() { - if (!\Civi::settings()->get('logging')) { + public static function useLoggingReport(): int { + $loggingSchema = new CRM_Logging_Schema(); + if (!$loggingSchema->isEnabled()) { return FALSE; } - - $loggingSchema = new CRM_Logging_Schema(); - - if ($loggingSchema->isEnabled()) { - $params = ['report_id' => 'logging/contact/summary']; - $instance = []; - CRM_Report_BAO_ReportInstance::retrieve($params, $instance); - - if (!empty($instance) && - (empty($instance['permission']) || - (!empty($instance['permission']) && CRM_Core_Permission::check($instance['permission'])) - ) - ) { - return $instance['id']; - } + try { + // Use civicrm_api4 wrapper as it will exception rather than fatal if civi-report disabled. + return civicrm_api4('ReportInstance', 'get', [ + 'where' => [['report_id', '=', 'logging/contact/summary']], + ])->first()['id'] ?? FALSE; + } + catch (CRM_Core_Exception $e) { + // Either CiviReport is disabled or the contact does not have permission to + // view the summary report. Return FALSE to use the basic log. + return FALSE; } - - return FALSE; } } diff --git a/CRM/Utils/Check/Component/Env.php b/CRM/Utils/Check/Component/Env.php index d37a0ce6cb9d..72427d69f99c 100644 --- a/CRM/Utils/Check/Component/Env.php +++ b/CRM/Utils/Check/Component/Env.php @@ -9,6 +9,9 @@ +--------------------------------------------------------------------+ */ +use Civi\Api4\Extension; +use Psr\Log\LogLevel; + /** * * @package CRM @@ -200,7 +203,7 @@ public function checkDomainNameEmail($force = FALSE) { return $messages; } - list($domainEmailName, $domainEmailAddress) = CRM_Core_BAO_Domain::getNameAndEmail(TRUE); + [$domainEmailName, $domainEmailAddress] = CRM_Core_BAO_Domain::getNameAndEmail(TRUE); $domain = CRM_Core_BAO_Domain::getDomain(); $domainName = $domain->name; $fixEmailUrl = CRM_Utils_System::url("civicrm/admin/options/from_email_address", "&reset=1"); @@ -766,7 +769,7 @@ public function checkComponents(): array { $messages = []; $setting = Civi::settings()->get('enable_components'); - $exts = \Civi\Api4\Extension::get(FALSE) + $exts = Extension::get(FALSE) ->addWhere('key', 'LIKE', 'civi_%') ->addWhere('status', '=', 'installed') ->execute() @@ -859,6 +862,31 @@ public function checkExtensionUpgrades() { return []; } + /** + * Checks if logging is enabled but Civi-report is not. + * + * @return CRM_Utils_Check_Message[] + * @throws \CRM_Core_Exception + */ + public function checkLoggingHasCiviReport(): array { + if (Civi::settings()->get('logging')) { + $isEnabledCiviReport = (bool) Extension::get(FALSE) + ->addWhere('key', '=', 'civi_report') + ->addWhere('status', '=', 'installed') + ->execute()->countFetched(); + return $isEnabledCiviReport ? [] : [ + new CRM_Utils_Check_Message( + __FUNCTION__, + ts('You have enabled detailed logging but to display this in the change log tab CiviReport must be enabled'), + ts('CiviReport required to display detailed logging.'), + LogLevel::WARNING, + 'fa-plug' + ), + ]; + } + return []; + } + /** * Checks if CiviCRM database version is up-to-date * @return CRM_Utils_Check_Message[] diff --git a/tests/phpunit/CRM/Utils/Check/Component/EnvTest.php b/tests/phpunit/CRM/Utils/Check/Component/EnvTest.php index 45efbd877672..c32c3300e08f 100644 --- a/tests/phpunit/CRM/Utils/Check/Component/EnvTest.php +++ b/tests/phpunit/CRM/Utils/Check/Component/EnvTest.php @@ -8,23 +8,56 @@ */ class CRM_Utils_Check_Component_EnvTest extends CiviUnitTestCase { - public function setUp(): void { - parent::setUp(); - $this->useTransaction(); + public function tearDown(): void { + Civi::settings()->set('logging', FALSE); + parent::tearDown(); } - /** * File check test should fail if reached maximum timeout. * @throws \GuzzleHttp\Exception\GuzzleException */ public function testResourceUrlCheck(): void { - $check = new \CRM_Utils_Check_Component_Env(); + $check = new CRM_Utils_Check_Component_Env(); $failRequest = $check->fileExists('https://civicrm.org', 0.001); $successRequest = $check->fileExists('https://civicrm.org', 0); - $this->assertEquals(FALSE, $failRequest, 'Request should fail for minimum timeout.'); - $this->assertEquals(TRUE, $successRequest, 'Request should not fail for infinite timeout.'); + $this->assertFalse($failRequest, 'Request should fail for minimum timeout.'); + $this->assertTrue($successRequest, 'Request should not fail for infinite timeout.'); + } + + /** + * Test the check that warns users if they have enabled logging but not Civi-report. + * + * The check should not be triggered if logging is not enabled or it + * is enabled and civi-report is enabled. + * + * @return void + */ + public function testLoggingWithReport(): void { + $this->callAPISuccess('Extension', 'disable', ['key' => 'civi_report']); + $this->assertFalse($this->checkChecks('checkLoggingHasCiviReport')); + + Civi::settings()->set('logging', 1); + $check = $this->checkChecks('checkLoggingHasCiviReport'); + $this->assertEquals('CiviReport required to display detailed logging.', $check['title']); + + $this->callAPISuccess('Extension', 'install', ['key' => 'civi_report']); + $this->assertFalse($this->checkChecks('checkLoggingHasCiviReport')); + } + /** + * Check the checks are checking for the checky thing. + * + * @return bool|array + */ + public function checkChecks($checkName) { + $checks = $this->callAPISuccess('System', 'check'); + foreach ($checks['values'] as $check) { + if ($check['name'] === $checkName) { + return $check; + } + } + return FALSE; } }