mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 10:23:17 +00:00

- Squashed Pull request #1730 - Squashed Pull request #1741 - Squashed Pull request #1742 - Squash merge branch 4.0 - Squashed Pull request #1744 - Squashed Pull request #1746 - Squashed merge branch 4.0 - Squashed merge branch 4.0 - Squashed merge branch 4.0 - Squashed merge branch 4.0 - Squashed Pull request #1758 - Avoid using imagine/imagine alias as it is causing install issues - Squashed merge branch 4.0 - Squashed Pull request #1763 - Squashed merge branch 4.0 - Squash of 6 commits - Squashed merge branch 4.0 - This is a combination of 2 commits. - Squashed Pull request #1775 - Squashed Pull request #1777 - Squashed Pull request #1779 - Squashed Pull request #1780 - Squashed Pull request #1782 - Adds a Pull request template - Squased Pull request #1783 - Squash Pull request #1786 - Squashed Pull request #1796 - Squashed merge branch 4.0 - Squash Pull request #1791 - Squashed merge branch 4.0 - Squashed Pull request #1808 - Squashed Pull request #1811 - Squashed Pull request #1809
196 lines
4.7 KiB
PHP
196 lines
4.7 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2016 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Alchemy\Phrasea\SearchEngine;
|
|
|
|
use Alchemy\Phrasea\Exception\RuntimeException;
|
|
use Alchemy\Phrasea\Model\Entities\FeedEntry;
|
|
use Doctrine\Common\Collections\ArrayCollection;
|
|
|
|
interface SearchEngineInterface
|
|
{
|
|
const TYPE_ELASTICSEARCH = 'elasticsearch';
|
|
const TYPE_PHRASEA = 'phrasea';
|
|
|
|
const GEM_TYPE_RECORD = 'record';
|
|
const GEM_TYPE_STORY = 'story';
|
|
const GEM_TYPE_ENTRY = 'entry';
|
|
|
|
/**
|
|
* Returns the name of the search engine
|
|
*
|
|
* @return string The name of the search-engine
|
|
*/
|
|
public function getName();
|
|
|
|
/**
|
|
* Check the status of the search engine
|
|
*
|
|
* @return array An array of key/value parameters
|
|
* @throws RuntimeException if something is wrong
|
|
*/
|
|
public function getStatus();
|
|
|
|
/**
|
|
* @return array an array of field names
|
|
*/
|
|
public function getAvailableDateFields();
|
|
|
|
/**
|
|
* @return array an array containing criteria values as key and criteria names as value
|
|
*/
|
|
public function getAvailableSort();
|
|
|
|
/**
|
|
* @return string The default sort
|
|
*/
|
|
public function getDefaultSort();
|
|
|
|
/**
|
|
* @return string The default sort direction
|
|
*/
|
|
public function getDefaultSortDirection();
|
|
|
|
/**
|
|
* @return string The default sort
|
|
*/
|
|
public function isStemmingEnabled();
|
|
|
|
/**
|
|
* @return array an array containing sort order values as key and sort order names as value
|
|
*/
|
|
public function getAvailableOrder();
|
|
|
|
/**
|
|
* @return Boolean return true if the search engine supports stemmed search
|
|
*/
|
|
public function hasStemming();
|
|
|
|
/**
|
|
*
|
|
* @return array an array of self::GEM_TYPE_* indexed types
|
|
*/
|
|
public function getAvailableTypes();
|
|
|
|
/**
|
|
* Add a record to index
|
|
*
|
|
* @param \record_adapter $record
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function addRecord(\record_adapter $record);
|
|
|
|
/**
|
|
* Remove a record from index
|
|
*
|
|
* @param \record_adapter $record
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function removeRecord(\record_adapter $record);
|
|
|
|
/**
|
|
* Update a record in index
|
|
*
|
|
* @param \record_adapter $record
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function updateRecord(\record_adapter $record);
|
|
|
|
/**
|
|
* Add a story to index
|
|
*
|
|
* @param \record_adapter $story
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function addStory(\record_adapter $story);
|
|
|
|
/**
|
|
* Remove a story from index
|
|
*
|
|
* @param \record_adapter $story
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function removeStory(\record_adapter $story);
|
|
|
|
/**
|
|
* Update a story in index
|
|
*
|
|
* @param \record_adapter $story
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function updateStory(\record_adapter $story);
|
|
|
|
/**
|
|
* Add an entry to index
|
|
*
|
|
* @param FeedEntry $entry
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function addFeedEntry(FeedEntry $entry);
|
|
|
|
/**
|
|
* Remove an entry to index
|
|
*
|
|
* @param FeedEntry $entry
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function removeFeedEntry(FeedEntry $entry);
|
|
|
|
/**
|
|
* Update an entry in the index
|
|
*
|
|
* @param FeedEntry $entry
|
|
* @return SearchEngineInterface
|
|
* @throws RuntimeException
|
|
*/
|
|
public function updateFeedEntry(FeedEntry $entry);
|
|
|
|
/**
|
|
* @param string $query
|
|
* @param SearchEngineOptions $options
|
|
*
|
|
* @return SearchEngineResult
|
|
*/
|
|
public function query($query, SearchEngineOptions $options = null);
|
|
|
|
/**
|
|
* Return an array of suggestions corresponding to the last word of the
|
|
* query
|
|
*
|
|
* @param string $query
|
|
*
|
|
* @return ArrayCollection A collection of SearchEngineSuggestion
|
|
*/
|
|
public function autocomplete($query, SearchEngineOptions $options);
|
|
|
|
/**
|
|
* Reset the cache of the SE (if applicable)
|
|
*
|
|
* @return SearchEngineInterface
|
|
*/
|
|
public function resetCache();
|
|
|
|
/**
|
|
* Clear the cache of the SE for the current user (if applicable)
|
|
*
|
|
* @return SearchEngineInterface
|
|
*/
|
|
public function clearCache();
|
|
}
|