0
0
mirror of https://github.com/salesagility/SuiteCRM.git synced 2024-11-25 08:57:55 +00:00
salesagility_SuiteCRM/lib/Robo/Plugin/Commands/ElasticSearchCommands.php
2023-07-18 15:53:09 +01:00

172 lines
5.9 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 - 2018 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\Robo\Plugin\Commands;
use BeanFactory;
use Robo\Tasks;
use SuiteCRM\Robo\Traits\CliRunnerTrait;
use SuiteCRM\Robo\Traits\RoboTrait;
use SuiteCRM\Search\ElasticSearch\ElasticSearchIndexer;
use SuiteCRM\Search\Index\Documentify\JsonSerializerDocumentifier;
use SuiteCRM\Search\Index\Documentify\SearchDefsDocumentifier;
use SuiteCRM\Search\SearchQuery;
use SuiteCRM\Search\SearchResults;
use SuiteCRM\Search\SearchWrapper;
use SuiteCRM\Utility\BeanJsonSerializer;
/**
* Class ElasticSearchCommands
*
* @package SuiteCRM\Robo\Plugin\Commands
*/
#[\AllowDynamicProperties]
class ElasticSearchCommands extends Tasks
{
use RoboTrait;
use CliRunnerTrait;
/**
* Performs a search using the given parameters.
*
* The full Elasticsearch query string syntax is available. See link below.
*
* @see https://www.elastic.co/guide/en/elasticsearch/reference/5.5/query-dsl-query-string-query.html#query-string-syntax
*
* @param string $query The search query. See elasticsearch syntax.
* @param int $size How many results to show
* @param bool $showJson if set to `1` shows a JSON for each results.
*/
public function elasticSearch($query, $size = 20, $showJson = false)
{
$this->bootstrap();
$engine = new SearchWrapper();
$result = $engine->search('ElasticSearchEngine', SearchQuery::fromString($query, $size));
$hits = $result->getHits();
if (empty($hits)) {
$this->io()->note('No results matching your query. Try broadening your criteria.');
$this->showSearchTime($result);
return;
}
$this->io()->title("Results");
foreach ($hits as $key => $module) {
$this->printModuleResults($showJson, $key, $module);
}
$this->showSearchTime($result);
}
/**
* Indexes the sql database in the Elasticsearch engine.
*
* Differential indexing will only update (and fetch) beans that have been created/modified/removed since the last
* run. This should be much faster than a full index.
*
* The two documentifiers differ slightly on the type of structure they output.
* See the relative classes to know more.
*
* NOTE: from CLI passing `true` or `false` won't work. Use `0` and `1`, instead as parameters.
*
* @param int $differential 0 = full index | 1 = differential index
* @param int $searchdefs 0 = BeanJsonSerializer | 1 = SearchDefsDocumentifier
*
* @see ElasticSearchIndexer::index()
* @see SearchDefsDocumentifier
* @see JsonSerializerDocumentifier
*/
public function elasticIndex($differential = 1, $searchdefs = 0)
{
$this->bootstrap();
ElasticSearchIndexer::repairElasticsearchIndex($differential, $searchdefs);
}
/**
* Deletes the Elasticsearch index.
*/
public function elasticRmIndex()
{
$this->bootstrap();
$indexer = new ElasticSearchIndexer();
$indexer->removeIndex();
}
/**
* Print the results for each module.
*
* @param bool $showJson
* @param string $module
* @param array $ids
*/
private function printModuleResults($showJson, $module, array $ids)
{
$this->io()->section($module);
$results = [];
$json = BeanJsonSerializer::make();
foreach ($ids as $id) {
$bean = BeanFactory::getBean($module, $id);
$results[] = $showJson
? $json->serialize($bean, true, true)
: mb_convert_encoding($bean->name, 'UTF-8', 'HTML-ENTITIES');
}
$this->io()->listing($results);
}
/**
* Pretty prints the search time.
*
* @param SearchResults $result
*/
private function showSearchTime(SearchResults $result)
{
$time = round($result->getSearchTime() * 1000);
$this->io()->success("Search performed in $time ms");
}
}