mirror of
https://github.com/SuiteCRM/SuiteCRM-Core.git
synced 2025-08-29 08:17:18 +08:00
2aaee3c558 Implement PDFEngine bf78e964fd Fix PDF_Lib constructors cfe6e2a1e0 Replace deprecated fzaninotto/faker with fakerphp/faker 7f8d18b8fb Move test namespaces into autoload-dev 1778603d07 Upgrade nesbot/carbon to v2.x 171ef65335 Update Travis config to use composer v2.x 7a4d0007af Upgrade composer-merge-plugin to v2.x 0461d8f4ba Fix PHPUnit 9 deprecations and warnings 15906ef6a5 Fix test case class not matching filename deprecation warnings b92a9dcdbd Replace abandoned leafo/scssphp with scssphp/scssphp 9a0fea7c9e Upgrade Robo to v3.x 5462b82a22 Update composer.json 77d3575052 Fix missing default config values 1d4a0e7421 Consolidate global search settings e75e0f4add Remove duplicate "Global Search" link in the adminpanel 1bfa51fa73 Implement search engine selection d5a33281e1 Deprecate UnifiedSearchAdvanced fcce848d4c Unify search engines c8c02c5398 Remove new/legacy search engine labels e34cad759d Add codeception 4.1.x dependencies to composer cc3a504997 Migrate PHPUnit schema for 9.5.x ce5a63be20 Upgrade PHPUnit to 9.5.x f52dc24e61 Remove codeception 420303758e Fix tests remove incompletes c93e654768 Fix tests deprecated asserts 4feebbab22 Fix tests define return type hints abd327d267 Update test namespaces for PSR-4/PSR-8 f464e2a829 Fix tests redundant noinspection 5b74cc4d2c Fix tests misordered assert arguments 03a83246f4 Fix tests use appropriate asserts a04c048c18 Fix tests one-time use variables 683533e2b6 Fix tests method invocations 7e44ec9583 Update PHPUnit schema 2181ad7f3d Update Travis config to remove PHP 7.2 480a87c03a Update minimum required PHP to v7.3.0 200c6deb61 Update composer.lock git-subtree-dir: public/legacy git-subtree-split: 2aaee3c5581c025abca1114276e2d20c709f2812
189 lines
6.5 KiB
PHP
189 lines
6.5 KiB
PHP
<?php
|
|
/**
|
|
* SugarCRM Community Edition is a customer relationship management program developed by
|
|
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
|
|
*
|
|
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
|
|
* Copyright (C) 2011 - 2021 SalesAgility Ltd.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
* the terms of the GNU Affero General Public License version 3 as published by the
|
|
* Free Software Foundation with the addition of the following permission added
|
|
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
|
|
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
|
|
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License along with
|
|
* this program; if not, see http://www.gnu.org/licenses or write to the Free
|
|
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301 USA.
|
|
*
|
|
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
|
|
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
|
|
*
|
|
* The interactive user interfaces in modified source and object code versions
|
|
* of this program must display Appropriate Legal Notices, as required under
|
|
* Section 5 of the GNU Affero General Public License version 3.
|
|
*
|
|
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
|
|
* these Appropriate Legal Notices must retain the display of the "Powered by
|
|
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
|
|
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
|
|
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
|
|
*/
|
|
|
|
namespace SuiteCRM\Search\UI;
|
|
|
|
if (!defined('sugarEntry') || !sugarEntry) {
|
|
die('Not A Valid Entry Point');
|
|
}
|
|
|
|
use Elasticsearch\Common\Exceptions\NoNodesAvailableException;
|
|
use Exception;
|
|
use SuiteCRM\Search\Exceptions\SearchEngineNotFoundException;
|
|
use SuiteCRM\Search\Exceptions\SearchException;
|
|
use SuiteCRM\Search\Exceptions\SearchInvalidRequestException;
|
|
use SuiteCRM\Search\Exceptions\SearchUserFriendlyException;
|
|
use SuiteCRM\Search\SearchQuery;
|
|
use SuiteCRM\Search\SearchWrapper;
|
|
use SuiteCRM\Utility\SuiteLogger;
|
|
use Throwable;
|
|
use Whoops\Handler\PrettyPageHandler;
|
|
use Whoops\Run;
|
|
|
|
/**
|
|
* Class SearchThrowableHandler handles an Exception or Error thrown during the search process and displays an error
|
|
* screen.
|
|
*
|
|
* If developer mode is enabled, further details will be provided.
|
|
*/
|
|
class SearchThrowableHandler
|
|
{
|
|
/** @var Throwable The Exception or Error that has occurred */
|
|
private $throwable;
|
|
/** @var SearchQuery the current search query */
|
|
private $query;
|
|
|
|
/**
|
|
* SearchThrowableHandler constructor.
|
|
*
|
|
* @param Throwable $throwable
|
|
* @param SearchQuery $query
|
|
*/
|
|
public function __construct(Throwable $throwable, SearchQuery $query)
|
|
{
|
|
$this->throwable = $throwable;
|
|
$this->query = $query;
|
|
}
|
|
|
|
/**
|
|
* Shows the proper error message.
|
|
*
|
|
* If developer mode is enabled, a full exception page will be shown.
|
|
*/
|
|
public function handle(): void
|
|
{
|
|
global $sugar_config;
|
|
|
|
$logger = new SuiteLogger();
|
|
|
|
$prefix = '[SearchThrowableHandler] ';
|
|
$logger->error($prefix . $this->getFriendlyMessage());
|
|
$logger->error($prefix . $this->throwable);
|
|
|
|
if ($sugar_config['developerMode'] === true) {
|
|
$this->printStackTrace();
|
|
|
|
return;
|
|
}
|
|
|
|
$this->printFriendlyMessage();
|
|
}
|
|
|
|
/**
|
|
* Returns an error message that is user friendly.
|
|
*
|
|
* @return string
|
|
*/
|
|
private function getFriendlyMessage(): string
|
|
{
|
|
global $mod_strings;
|
|
|
|
switch (get_class($this->throwable)) {
|
|
case SearchUserFriendlyException::class:
|
|
$message = $this->throwable->getMessage();
|
|
break;
|
|
case SearchInvalidRequestException::class:
|
|
$message = $mod_strings['LBL_ELASTIC_SEARCH_EXCEPTION_SEARCH_INVALID_REQUEST'];
|
|
break;
|
|
case SearchEngineNotFoundException::class:
|
|
$message = $mod_strings['LBL_ELASTIC_SEARCH_EXCEPTION_SEARCH_ENGINE_NOT_FOUND'];
|
|
break;
|
|
case NoNodesAvailableException::class:
|
|
$message = $mod_strings['LBL_ELASTIC_SEARCH_EXCEPTION_NO_NODES_AVAILABLE'];
|
|
break;
|
|
case SearchException::class:
|
|
$message = $mod_strings['LBL_ELASTIC_SEARCH_EXCEPTION_SEARCH'];
|
|
break;
|
|
default:
|
|
$message = $mod_strings['LBL_ELASTIC_SEARCH_EXCEPTION_DEFAULT'];
|
|
}
|
|
|
|
return $message;
|
|
}
|
|
|
|
/**
|
|
* Cancels the current output and prints a full screen detailed exception page
|
|
*/
|
|
private function printStackTrace(): void
|
|
{
|
|
$whoops = new Run;
|
|
$handler = new PrettyPageHandler;
|
|
|
|
$handler->addDataTable('SearchQuery', $this->query->jsonSerialize());
|
|
$handler->addDataTable('SearchWrapper Status', $this->getSearchWrapperStatus());
|
|
|
|
$whoops->pushHandler($handler);
|
|
$whoops->register();
|
|
|
|
echo $whoops->handleException($this->throwable);
|
|
}
|
|
|
|
/**
|
|
* Returns an array with the SearchWrapper status to be displayed in the detailed view.
|
|
*
|
|
* @return array
|
|
*/
|
|
private function getSearchWrapperStatus(): ?array
|
|
{
|
|
try {
|
|
return [
|
|
'Available Engines' => implode(', ', SearchWrapper::getEngines()),
|
|
'Search Controller' => SearchWrapper::getController(),
|
|
'Default Search Engine' => SearchWrapper::getDefaultEngine(),
|
|
'Friendly Error Message' => $this->getFriendlyMessage(),
|
|
];
|
|
} catch (Exception $exception) {
|
|
return ['error' => 'failed to get SearchWrapper status'];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Prints the error on the page.
|
|
*/
|
|
private function printFriendlyMessage(): void
|
|
{
|
|
global $mod_strings;
|
|
|
|
$message = $this->getFriendlyMessage();
|
|
$endMessage = $mod_strings['LBL_ELASTIC_SEARCH_EXCEPTION_END_MESSAGE'];
|
|
|
|
echo '<h1>Error</h1>';
|
|
echo "<p class='text-danger'>$message $endMessage</p>";
|
|
}
|
|
}
|