[SearchEngine] Remove old files

This commit is contained in:
Romain Neutron
2012-08-24 11:38:38 +02:00
parent b10ae5e6f5
commit ac0c000a96
10 changed files with 0 additions and 4516 deletions

View File

@@ -1,160 +0,0 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
use Alchemy\Phrasea\Application;
/**
*
* @package searchEngine
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
class searchEngine_adapter
{
/**
*
* @var searchEngine_adapter_interface
*/
protected $search_engine;
/**
*
* @var searchEngine_adapter_options
*/
protected $search_options;
/**
*
* @var boolean
*/
protected $first_page = false;
/**
*
* @param registryInterface $registry
* @return searchEngine_adapter
*/
public function __construct(Application $app)
{
if ($app['phraseanet.registry']->get('GV_sphinx')) {
$this->search_engine = new searchEngine_adapter_sphinx_engine($app);
} elseif (function_exists('phrasea_query2')) {
$this->search_engine = new searchEngine_adapter_phrasea_engine($app);
} else {
throw new Exception('No search engine available, try phrasea2 or sphinx');
}
return $this;
}
/**
*
* @param searchEngine_options $options
* @return searchEngine_adapter
*/
public function set_options(searchEngine_options $options)
{
$this->search_options = $options;
$this->search_engine->set_options($options);
return $this;
}
/**
*
* @param boolean $boolean
* @return searchEngine_adapter
*/
public function set_is_first_page($boolean)
{
$this->first_page = ! ! $boolean;
return $this;
}
/**
*
* @return boolean
*/
public function is_first_page()
{
return $this->first_page;
}
/**
*
* @return string
*/
public function get_query()
{
return $this->search_engine->get_parsed_query();
}
/**
*
* @return searchEngine_adapter
*/
public function reset_cache()
{
$this->search_engine->reset_cache();
return $this;
}
/**
*
* @param string $query
* @param int $page
* @param int $perPage
* @return searchEngine_results
*/
public function query_per_page($query, $page, $perPage)
{
assert(is_int($page));
assert($page > 0);
assert(is_int($perPage));
assert($perPage > 0);
$offset = ($page - 1) * $perPage;
return $this->search_engine->results($query, $offset, $perPage);
}
/**
*
* @param string $query
* @param int $offset
* @param int $perPage
* @return searchEngine_results
*/
public function query_per_offset($query, $offset, $perPage)
{
assert(is_int($offset));
assert($offset >= 0);
assert(is_int($perPage));
assert($perPage > 0);
return $this->search_engine->results($query, $offset, $perPage);
}
/**
*
* @return array
*/
public function get_status()
{
return $this->search_engine->get_status();
}
public function build_excerpt($query, array $fields, record_adapter $record)
{
return $this->search_engine->build_excerpt($query, $fields, $record);
}
}

View File

@@ -1,199 +0,0 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
/**
*
* @package searchEngine
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
abstract class searchEngine_adapter_abstract
{
/**
*
* @var int
*/
protected $current_page;
/**
*
* @var int
*/
protected $total_results;
/**
*
* @var int
*/
protected $perPage;
/**
*
* @var string
*/
protected $query;
/**
*
* @var string
*/
protected $error = '';
/**
*
* @var string
*/
protected $warning = '';
/**
*
* @var int
*/
protected $total_available;
/**
*
* @var float
*/
protected $total_time;
/**
*
* @var int
*/
protected $offset_start;
/**
*
* @var boolean
*/
protected $use_stemming = true;
/**
*
* @var string
*/
protected $locale;
/**
*
* @var string
*/
protected $current_index = '';
/**
*
* @return int
*/
public function get_available_results()
{
return $this->total_available;
}
/**
*
* @return float
*/
public function get_time()
{
return $this->total_time;
}
/**
*
* @return string
*/
public function get_error()
{
return $this->error;
}
/**
*
* @return string
*/
public function get_warning()
{
return $this->warning;
}
/**
*
* @return string
*/
public function get_propositions()
{
return null;
}
/**
*
* @return searchEngine_adapter_abstract
*/
public function reset_cache()
{
return $this;
}
/**
*
* @return int
*/
public function get_per_page()
{
return (int) $this->perPage;
}
/**
*
* @return int
*/
public function get_total_results()
{
return (int) $this->total_results;
}
/**
*
* @return int
*/
public function get_total_pages()
{
return (int) ceil($this->get_available_results() / $this->get_per_page());
}
/**
*
* @return int
*/
public function get_current_page()
{
return (int) $this->current_page;
}
/**
*
* @return int
*/
public function get_offset_start()
{
return (int) $this->offset_start;
}
/**
*
* @return string
*/
public function get_current_indexes()
{
return $this->current_index;
}
}

View File

@@ -1,60 +0,0 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
use Alchemy\Phrasea\Application;
/**
*
* @package searchEngine
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
interface searchEngine_adapter_interface
{
public function __construct(Application $app);
public function set_options(searchEngine_options $options);
public function reset_cache();
public function get_time();
public function get_total_pages();
public function get_offset_start();
public function get_current_page();
public function get_per_page();
public function get_total_results();
public function get_available_results();
public function get_propositions();
public function get_parsed_query();
public function get_suggestions($I18n);
public function get_error();
public function get_warning();
public function get_current_indexes();
public function get_status();
public function results($query, $page, $perPage);
public function build_excerpt($query, array $fields, record_adapter $record);
}

View File

@@ -1,620 +0,0 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
use Alchemy\Phrasea\Application;
/**
*
* @package searchEngine
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
class searchEngine_adapter_phrasea_engine extends searchEngine_adapter_abstract implements searchEngine_adapter_interface
{
/**
*
* @var array
*/
protected $queries = array();
/**
*
* @var array
*/
protected $colls = array();
/**
*
* @var array
*/
protected $qp = array();
/**
*
* @var array
*/
protected $answers = array();
/**
*
* @var array
*/
protected $needthesaurus = array();
/**
*
* @var array
*/
protected $indep_treeq = array();
/**
*
* @var searchEngine_options
*/
protected $options = false;
/**
*
* @var array
*/
protected $arrayq = array();
/**
*
* @var array
*/
protected $results = array();
/**
*
* @var boolean
*/
protected $reseted = false;
/**
*
* @var int
*/
protected $opt_search_type;
/**
*
* @var array
*/
protected $opt_bases = array();
/**
*
* @var array
*/
protected $opt_fields = array();
/**
*
* @var array
*/
protected $opt_status = array();
/**
*
* @var array
*/
protected $opt_date_field;
/**
*
* @var DateTime
*/
protected $opt_min_date;
/**
*
* @var DateTime
*/
protected $opt_max_date;
/**
*
* @var string
*/
protected $opt_record_type;
protected $app;
/**
*
* @return searchEngine_adapter_phrasea_engine
*/
public function __construct(Application $app)
{
$this->app = $app;
return $this;
}
/**
*
* @param searchEngine_options $options
* @return searchEngine_adapter_phrasea_engine
*/
public function set_options(searchEngine_options $options)
{
$this->options = $options;
$this->opt_search_type = (int) $options->get_search_type();
$this->opt_bases = $options->get_bases();
$this->opt_fields = $options->get_fields();
$this->opt_date_field = $options->get_date_fields();
$this->opt_max_date = $options->get_max_date();
$this->opt_min_date = $options->get_min_date();
if (in_array($options->get_record_type(), array('image', 'video', 'audio', 'document', 'flash')))
$this->opt_record_type = $options->get_record_type();
foreach ($options->get_fields() as $field) {
if (trim($field) === 'phraseanet--all--fields') {
$this->opt_fields = array();
break;
}
}
$this->opt_status = $options->get_status();
return $this;
}
/**
*
* @param <type> $proposals
* @return string
*/
protected static function proposalsToHTML($proposals)
{
$html = '';
$b = true;
foreach ($proposals["BASES"] as $zbase) {
if ((int) (count($proposals["BASES"]) > 1) && count($zbase["TERMS"]) > 0) {
$style = $b ? 'style="margin-top:0px;"' : '';
$b = false;
$html .= "<h1 $style>" . sprintf(_('reponses::propositions pour la base %s'), $zbase["NAME"]) . "</h1>";
}
$t = true;
foreach ($zbase["TERMS"] as $path => $props) {
$style = $t ? 'style="margin-top:0px;"' : '';
$t = false;
$html .= "<h2 $style>" . sprintf(_('reponses::propositions pour le terme %s'), $props["TERM"]) . "</h2>";
$html .= $props["HTML"];
}
}
$html .= '';
return($html);
}
/**
*
* @return string
*/
public function get_propositions()
{
if (isset($this->qp['main'])) {
$proposals = self::proposalsToHTML($this->qp['main']->proposals);
if (trim($proposals) !== '') {
return "<div style='height:0px; overflow:hidden'>" . $this->qp['main']->proposals["QRY"]
. "</div><div class='proposals'>" . $proposals . "</div>";
}
}
return null;
}
/**
*
* @param int $query
* @param int $offset
* @param int $perPage
* @return searchEngine_results
*/
public function results($query, $offset, $perPage)
{
assert(is_int($offset));
assert($offset >= 0);
assert(is_int($perPage));
$page = floor($offset / $perPage) + 1;
$this->current_page = $page;
$this->perPage = $perPage;
$page = $this->get_current_page();
if (trim($query) === '')
$query = "all";
if ($this->opt_record_type != '') {
$query .= ' AND recordtype=' . $this->opt_record_type;
}
$sql = 'SELECT query, query_time FROM cache WHERE session_id = :ses_id';
$stmt = $this->app['phraseanet.appbox']->get_connection()->prepare($sql);
$stmt->execute(array(':ses_id' => $this->app['session']->get('phrasea_session_id')));
$row = $stmt->fetch(PDO::FETCH_ASSOC);
$stmt->closeCursor();
$date_obj = new DateTime('-10 min');
$date_quest = new DateTime($row['query_time']);
$reseted = $this->reseted;
$reseted = false;
if ($this->reseted)
$reseted = true;
if ($query != $row['query'])
$reseted = true;
if ($date_obj > $date_quest)
$reseted = true;
if ($reseted === true) {
$this->reset_cache();
self::addQuery($query);
self::query();
} else {
$this->total_available = $this->total_results = $this->app['session']->get('phraseanet.phrasea_engine_n_results');
}
$results = new set_result();
$perPage = $this->get_per_page();
$page = $this->get_current_page();
$this->offset_start = $courcahnum = (($page - 1) * $perPage);
$res = phrasea_fetch_results(
$this->app['session']->get('phrasea_session_id'), (int) (($page - 1) * $perPage) + 1, $perPage, false
);
$rs = array();
if (isset($res['results']) && is_array($res['results']))
$rs = $res['results'];
foreach ($rs as $irec => $data) {
try {
$sbas_id = phrasea::sbasFromBas($this->app, $data['base_id']);
$record = new record_adapter(
$this->app,
$sbas_id,
$data['record_id'],
$courcahnum
);
$results->add_element($record);
} catch (Exception $e) {
}
$courcahnum ++;
}
return new searchEngine_results($results, $this);
}
/**
*
* @return searchEngine_adapter_phrasea_engine
*/
public function reset_cache()
{
phrasea_clear_cache($this->app['session']->get('phrasea_session_id'));
$this->reseted = true;
return $this;
}
/**
*
* @return array
*/
public function get_status()
{
$infos = phrasea_info();
$status = array();
foreach ($infos as $key => $value) {
$status[] = array($key, $value);
}
return $status;
}
public function get_suggestions($I18n)
{
$props = array();
foreach ($this->qp['main']->proposals['QUERIES'] as $prop) {
$props[] = array(
'value' => $prop
, 'current' => false
, 'hits' => null
);
}
return $props;
}
/**
*
* @return string
*/
public function get_parsed_query()
{
return $this->query;
}
/**
*
* @return searchEngine_adapter_phrasea_engine
*/
protected function query()
{
$dateLog = date("Y-m-d H:i:s");
$nbanswers = 0;
$sql = 'UPDATE cache SET query = :query, query_time = NOW()
WHERE session_id = :ses_id';
$params = array(
'query' => $this->get_parsed_query()
, ':ses_id' => $this->app['session']->get('phrasea_session_id')
);
$stmt = $this->app['phraseanet.appbox']->get_connection()->prepare($sql);
$stmt->execute($params);
$stmt->closeCursor();
$total_time = 0;
$sort = '';
if ($this->options->get_sortby()) {
switch ($this->options->get_sortord()) {
case searchEngine_options::SORT_MODE_ASC:
$sort = '+';
break;
case searchEngine_options::SORT_MODE_DESC:
default:
$sort = '-';
break;
}
$sort .= '0' . $this->options->get_sortby();
}
foreach ($this->queries as $sbas_id => $qry) {
$BF = array();
foreach ($this->options->get_business_fields() as $base_id) {
$BF[] = phrasea::collFromBas($this->app, $base_id);
}
$this->results[$sbas_id] = phrasea_query2(
$this->app['session']->get('phrasea_session_id')
, $sbas_id
, $this->colls[$sbas_id]
, $this->arrayq[$sbas_id]
, $this->app['phraseanet.registry']->get('GV_sit')
, (string) $this->app['phraseanet.user']->get_id()
, false
, $this->opt_search_type == 1 ? PHRASEA_MULTIDOC_REGONLY : PHRASEA_MULTIDOC_DOCONLY
, $sort
, $BF
);
$total_time += $this->results[$sbas_id]['time_all'];
if ($this->results[$sbas_id])
$nbanswers += $this->results[$sbas_id]["nbanswers"];
$logger = $this->app['phraseanet.logger']($this->app['phraseanet.appbox']->get_databox($sbas_id));
$conn2 = connection::getPDOConnection($this->app, $sbas_id);
$sql3 = "INSERT INTO log_search
(id, log_id, date, search, results, coll_id )
VALUES
(null, :log_id, :date, :query, :nbresults, :colls)";
$params = array(
':log_id' => $logger->get_id()
, ':date' => $dateLog
, ':query' => $this->query
, ':nbresults' => $this->results[$sbas_id]["nbanswers"]
, ':colls' => implode(',', $this->colls[$sbas_id])
);
$stmt = $conn2->prepare($sql3);
$stmt->execute($params);
$stmt->closeCursor();
}
$this->total_time = $total_time;
User_Adapter::saveQuery($this->app, $this->query);
$this->app['session']->set('phraseanet.phrasea_engine_n_results', $nbanswers);
$this->total_available = $this->total_results = $nbanswers;
return $this;
}
/**
*
* @param int $sbas
* @return searchEngine_adapter_phrasea_engine
*/
protected function singleParse($sbas)
{
$this->qp[$sbas] = new searchEngine_adapter_phrasea_queryParser($this->app, $this->app['locale']);
$this->qp[$sbas]->debug = false;
if ($sbas == 'main')
$simple_treeq = $this->qp[$sbas]->parsequery($this->query);
else
$simple_treeq = $this->qp[$sbas]->parsequery($this->queries[$sbas]);
$this->qp[$sbas]->priority_opk($simple_treeq);
$this->qp[$sbas]->distrib_opk($simple_treeq);
$this->needthesaurus[$sbas] = false;
$this->indep_treeq[$sbas] = $this->qp[$sbas]->extendThesaurusOnTerms($simple_treeq, true, true, false);
$this->needthesaurus[$sbas] = $this->qp[$sbas]->containsColonOperator($this->indep_treeq[$sbas]);
return $this;
}
/**
*
* @param string $query
* @return searchEngine_adapter_phrasea_engine
*/
protected function addQuery($query)
{
$qry = '';
if (trim($query) != '') {
$qry .= trim($query);
}
foreach ($this->app['phraseanet.appbox']->get_databoxes() as $databox) {
foreach ($databox->get_collections() as $coll) {
if (in_array($coll->get_base_id(), $this->opt_bases)) {
$this->queries[$databox->get_sbas_id()] = $qry;
break;
}
}
}
$this->query = $qry;
foreach ($this->queries as $sbas => $qs) {
if ($sbas === 'main')
continue;
if (count($this->opt_status) > 0) {
$requestStat = 'xxxx';
for ($i = 4; ($i <= 64); $i ++ ) {
if ( ! isset($this->opt_status[$i])) {
$requestStat = 'x' . $requestStat;
continue;
}
$set = false;
$val = '';
if (isset($this->opt_status[$i][$sbas]) && $this->opt_status[$i][$sbas] == '0') {
$set = true;
$val = '0';
}
if (isset($this->opt_status[$i][$sbas]) && $this->opt_status[$i][$sbas] == '1') {
if ($set)
$val = 'x';
else
$val = '1';
}
$requestStat = ( $val != '' ? $val : 'x' ) . $requestStat;
}
$requestStat = trim(ltrim($requestStat, 'x'));
if ($requestStat !== '')
$this->queries[$sbas] .= ' and (recordstatus=' . $requestStat . ')';
}
if (count($this->opt_fields) > 0) {
$this->queries[$sbas] .= ' dans (' . implode(' ou ', $this->opt_fields) . ')';
}
if (($this->opt_min_date || $this->opt_max_date) && $this->opt_date_field != '') {
if ($this->opt_min_date)
$this->queries[$sbas] .= ' AND ( ' . implode(' >= ' . $this->opt_min_date->format('Y-m-d') . ' OR ', $this->opt_date_field) . ' >= ' . $this->opt_min_date->format('Y-m-d') . ' ) ';
if ($this->opt_max_date)
$this->queries[$sbas] .= ' AND ( ' . implode(' <= ' . $this->opt_max_date->format('Y-m-d') . ' OR ', $this->opt_date_field) . ' <= ' . $this->opt_max_date->format('Y-m-d') . ' ) ';
}
}
$this->singleParse('main');
foreach ($this->queries as $sbas => $qryBas)
$this->singleParse($sbas);
foreach ($this->app['phraseanet.appbox']->get_databoxes() as $databox) {
if ( ! isset($this->queries[$databox->get_sbas_id()]))
continue;
$sbas_id = $databox->get_sbas_id();
$this->colls[$sbas_id] = array();
foreach ($databox->get_collections() as $coll) {
if (in_array($coll->get_base_id(), $this->opt_bases))
$this->colls[$sbas_id][] = (int) $coll->get_base_id();
}
if (sizeof($this->colls[$sbas_id]) <= 0)
continue;
if ($this->needthesaurus[$sbas_id]) {
$domthesaurus = $databox->get_dom_thesaurus();
if ($domthesaurus) {
$this->qp[$sbas_id]->thesaurus2($this->indep_treeq[$sbas_id], $sbas_id, $databox->get_dbname(), $domthesaurus, true);
$this->qp['main']->thesaurus2($this->indep_treeq['main'], $sbas_id, $databox->get_dbname(), $domthesaurus, true);
}
}
if ($this->qp[$sbas_id]->errmsg != "") {
$this->error .= ' ' . $this->qp[$sbas_id]->errmsg;
}
$emptyw = false;
$this->qp[$sbas_id]->set_default($this->indep_treeq[$sbas_id], $emptyw);
$this->qp[$sbas_id]->distrib_in($this->indep_treeq[$sbas_id]);
$this->qp[$sbas_id]->factor_or($this->indep_treeq[$sbas_id]);
$this->qp[$sbas_id]->setNumValue($this->indep_treeq[$sbas_id], $databox->get_sxml_structure());
$this->qp[$sbas_id]->thesaurus2_apply($this->indep_treeq[$sbas_id], $sbas_id);
$this->arrayq[$sbas_id] = $this->qp[$sbas_id]->makequery($this->indep_treeq[$sbas_id]);
$this->results[$sbas_id] = NULL;
}
return $this;
}
public function build_excerpt($query, array $fields, record_adapter $record)
{
$ret = array();
$res = phrasea_fetch_results(
$this->app['session']->get('phrasea_session_id'), ($record->get_number() + 1), 1, true, "[[em]]", "[[/em]]"
);
if ( ! isset($res['results']) || ! is_array($res['results'])) {
return array();
}
$rs = $res['results'];
$res = array_shift($rs);
if ( ! isset($res['xml'])) {
return array();
}
$sxe = simplexml_load_string($res['xml']);
foreach ($fields as $name => $field) {
if (false !== $sxe && $sxe->description && $sxe->description->$name) {
$val = array();
foreach ($sxe->description->$name as $value) {
$val[] = str_replace(array('[[em]]', '[[/em]]'), array('<em>', '</em>'), (string) $value);
}
$separator = $field['separator'] ? $field['separator'][0] : '';
$val = implode(' ' . $separator . ' ', $val);
} else {
$val = $field['value'];
}
$ret[] = $val;
}
return $ret;
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -1,703 +0,0 @@
<?php
require_once __DIR__ . '/../../../../vendor/sphinx/sphinxapi.php';
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
use Alchemy\Phrasea\Application;
/**
*
* @package searchEngine
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
class searchEngine_adapter_sphinx_engine extends searchEngine_adapter_abstract implements searchEngine_adapter_interface
{
/**
*
* @var sphinxClient
*/
protected $sphinx;
/**
*
* @var array
*/
protected $distinct_sbas = array();
/**
*
* @var boolean
*/
protected $search_in_field = false;
/**
*
* @var searchEngine_options
*/
protected $options;
/**
*
* @var boolean
*/
protected $search_unique_record = false;
protected $app;
/**
*
* @return searchEngine_adapter_sphinx_engine
*/
public function __construct(Application $app)
{
$this->app = $app;
$this->sphinx = new SphinxClient ();
$this->sphinx->SetArrayResult(true);
$this->sphinx->SetServer($this->app['phraseanet.registry']->get('GV_sphinx_host'), (int) $this->app['phraseanet.registry']->get('GV_sphinx_port'));
$this->sphinx->SetConnectTimeout(1);
return $this;
}
/**
*
* @param searchEngine_options $options
* @return searchEngine_adapter_sphinx_engine
*/
public function set_options(searchEngine_options $options)
{
$this->options = $options;
$filters = array();
$sbas_ids = array();
$this->use_stemming = $options->get_use_stemming();
$this->locale = $options->get_locale();
foreach ($options->get_bases() as $bas) {
$this->distinct_sbas[phrasea::sbasFromBas($this->app, $bas)] = true;
$key = phrasea::sbasFromBas($this->app, $bas) . '_' . phrasea::collFromBas($this->app, $bas);
$sbas_id = phrasea::sbasFromBas($this->app, $bas);
$sbas_ids[$sbas_id] = $sbas_id;
$filters[] = crc32($key);
}
if ($filters) {
$this->sphinx->SetFilter('crc_sbas_coll', $filters);
}
$this->sphinx->SetFilter('deleted', array(0));
$filters = array();
foreach ($sbas_ids as $sbas_id) {
$fields = $this->app['phraseanet.appbox']->get_databox($sbas_id)->get_meta_structure();
foreach ($fields as $field) {
if ( ! in_array($field->get_id(), $options->get_fields()))
continue;
$key = $sbas_id . '_' . $field->get_id();
$filters[] = crc32($key);
$this->search_in_field = true;
}
}
$crc_coll_business = array();
if ($options->get_business_fields()) {
$this->search_in_field = true;
foreach ($options->get_business_fields() as $base_id) {
$crc_coll_business[] = crc32(phrasea::collFromBas($this->app, $base_id) . '_1');
$crc_coll_business[] = crc32(phrasea::collFromBas($this->app, $base_id) . '_0');
}
$non_business = array_diff($options->get_bases(), $options->get_business_fields());
foreach ($non_business as $base_id) {
$crc_coll_business[] = crc32(phrasea::collFromBas($this->app, $base_id) . '_0');
}
$this->sphinx->SetFilter('crc_coll_business', $crc_coll_business);
} elseif ($this->search_in_field) {
$this->sphinx->SetFilter('business', array(0));
}
if ($filters) {
$this->sphinx->SetFilter('crc_struct_id', $filters);
}
/**
* @todo : enhance : check status better
*/
foreach ($sbas_ids as $sbas_id) {
$s_status = $this->app['phraseanet.appbox']->get_databox($sbas_id)->get_statusbits();
$status_opts = $options->get_status();
foreach ($s_status as $n => $status) {
if ( ! array_key_exists($n, $status_opts))
continue;
if ( ! array_key_exists($sbas_id, $status_opts[$n]))
continue;
$crc = crc32($sbas_id . '_' . $n);
$this->sphinx->SetFilter('status', array($crc), ($status_opts[$n][$sbas_id] == '0'));
}
}
$this->sphinx->SetFilter('parent_record_id', array($options->get_search_type()));
$filters = array();
if ($options->get_record_type() != '') {
$filters[] = crc32($options->get_record_type());
}
if ($filters) {
$this->sphinx->SetFilter('crc_type', $filters);
}
$ord = '';
switch ($options->get_sortord()) {
case searchEngine_options::SORT_MODE_ASC:
$ord = 'ASC';
break;
case searchEngine_options::SORT_MODE_DESC:
default:
$ord = 'DESC';
break;
}
switch ($options->get_sortby()) {
case searchEngine_options::SORT_RANDOM:
$sort = '@random';
break;
case searchEngine_options::SORT_RELEVANCE:
default:
$sort = '@relevance ' . $ord . ', created_on ' . $ord;
break;
case searchEngine_options::SORT_CREATED_ON:
$sort = 'created_on ' . $ord;
break;
}
$this->sphinx->SetGroupBy('crc_sbas_record', SPH_GROUPBY_ATTR, $sort);
return $this;
}
/**
*
* @return array
*/
public function get_status()
{
$status = $this->sphinx->Status();
if (false === $status)
throw new Exception(_('Sphinx server is offline'));
return $status;
}
/**
*
* @return searchEngine_adapter_sphinx_engine
*/
protected function parse_query()
{
$this->query = trim($this->query);
while (substr($this->query, 0, 1) === '(' && substr($this->query, -1) === ')')
$this->query = substr($this->query, 1, (mb_strlen($this->query) - 2));
if ($this->query == 'all')
$this->query = '';
while (mb_strpos($this->query, ' ') !== false) {
$this->query = str_replace(' ', ' ', $this->query);
}
$preg = preg_match('/\s?recordid\s?=\s?([0-9]+)/i', $this->query, $matches, 0, 0);
if ($preg > 0) {
$this->sphinx->SetFilter('record_id', array($matches[1]));
$this->query = '';
$this->search_unique_record = true;
} else {
$offset = 0;
while (($pos = mb_strpos($this->query, '-', $offset)) !== false) {
$offset = $pos + 1;
if ($pos === 0) {
continue;
}
if (mb_substr($this->query, ($pos - 1), 1) !== ' ') {
$this->query = mb_substr($this->query, 0, ($pos)) . ' ' . mb_substr($this->query, $pos + 1);
}
}
$this->query = str_ireplace(array(' ou ', ' or '), '|', $this->query);
$this->query = str_ireplace(array(' sauf ', ' except '), ' -', $this->query);
$this->query = str_ireplace(array(' and ', ' et '), ' +', $this->query);
}
return $this;
}
/**
*
* @param string $query
* @param int $offset
* @param int $perPage
* @return searchEngine_results
*/
public function results($query, $offset, $perPage)
{
assert(is_int($offset));
assert($offset >= 0);
assert(is_int($perPage));
$page = ceil($offset / $perPage) + 1;
$this->current_page = $page;
$this->perPage = $perPage;
$this->offset_start = $offset;
$this->query = $query;
$this->sphinx->SetLimits($offset, $this->perPage);
$this->sphinx->SetMatchMode(SPH_MATCH_EXTENDED2);
$this->parse_query();
$index = '*';
$params = phrasea::sbas_params($this->app);
$index_keys = array();
foreach ($params as $sbas_id => $params) {
if ( ! array_key_exists($sbas_id, $this->distinct_sbas))
continue;
$index_keys[] = crc32(str_replace(array('.', '%'), '_', sprintf('%s_%s_%s_%s', $params['host'], $params['port'], $params['user'], $params['dbname'])));
}
if (count($index_keys) > 0) {
if ($this->search_in_field === false) {
$index = '';
$found = false;
if ($this->query !== '' && $this->options->get_use_stemming()) {
if ($this->app['locale.I18n'] == 'fr') {
$index .= ', documents' . implode('_stemmed_fr, documents', $index_keys) . '_stemmed_fr';
$found = true;
} elseif ($this->app['locale.I18n'] == 'en') {
$index .= ', documents' . implode('_stemmed_en, documents', $index_keys) . '_stemmed_en';
$found = true;
}
}
if ( ! $found)
$index .= 'documents' . implode(', documents', $index_keys);
$index .= ', docs_realtime' . implode(', docs_realtime', $index_keys);
} else {
$index = '';
$found = false;
if ($this->query !== '' && $this->options->get_use_stemming() && $this->app['locale.I18n'] == 'fr') {
if ($this->app['locale.I18n'] == 'fr') {
$index .= ', metadatas' . implode('_stemmed_fr, metadatas', $index_keys) . '_stemmed_fr';
$found = true;
} elseif ($this->app['locale.I18n'] == 'en') {
$index .= ', metadatas' . implode('_stemmed_en, metadatas', $index_keys) . '_stemmed_en';
$found = true;
}
}
if ( ! $found)
$index = 'metadatas' . implode(',metadatas', $index_keys);
$index .= ', metas_realtime' . implode(', metas_realtime', $index_keys);
}
}
$this->current_index = $index;
$res = $this->sphinx->Query($this->query, $this->current_index);
$results = new set_result();
if ($res === false) {
if ($this->sphinx->IsConnectError() === true) {
$this->error = _('Sphinx server is offline');
} else {
$this->error = $this->sphinx->GetLastError();
}
$this->warning = $this->sphinx->GetLastWarning();
} else {
$this->error = $res['error'];
$this->warning = $res['warning'];
$this->total_time = $res['time'];
$this->total_results = $res['total_found'];
$this->total_available = $res['total'];
$courcahnum = $this->offset_start;
if (isset($res['matches'])) {
foreach ($res['matches'] as $record_id => $match) {
try {
$record =
new record_adapter(
$this->app,
$match['attrs']['sbas_id']
, $match['attrs']['record_id']
, $courcahnum
);
$results->add_element($record);
} catch (Exception $e) {
}
$courcahnum ++;
}
}
}
return new searchEngine_results($results, $this);
}
/**
*
* @param string $keyword
* @return string
*/
public function BuildTrigrams($keyword)
{
$t = "__" . $keyword . "__";
$trigrams = "";
for ($i = 0; $i < strlen($t) - 2; $i ++ )
$trigrams .= substr($t, $i, 3) . " ";
return $trigrams;
}
// public function get_index_suggestions($keyword)
// {
// $trigrams = $this->BuildTrigrams($keyword);
// $query = "\"$trigrams\"/1";
// $len = strlen($keyword);
//
// $this->sphinx->SetArrayResult(true);
//
// $this->sphinx->SetMatchMode(SPH_MATCH_EXTENDED2);
// $this->sphinx->SetRankingMode(SPH_RANK_WORDCOUNT);
// $this->sphinx->SetFilterRange("len", $len - 2, $len + 2);
// $this->sphinx->SetSelect("*, @weight+2-abs(len-$len) AS myrank");
// $this->sphinx->SetSortMode(SPH_SORT_EXTENDED, "myrank DESC, freq DESC");
// $this->sphinx->SetLimits(0, 10);
//
// $params = phrasea::sbas_params();
//
// $index_keys = array();
// foreach ($params as $sbas_id => $p)
// {
// $index_keys[] = crc32(str_replace(array('.', '%'), '_', sprintf('%s_%s_%s_%s', $p['host'], $p['port'], $p['user'], $p['dbname'])));
// }
// $index = 'suggest' . implode(',suggest', $index_keys);
//
// $res = $this->sphinx->Query($query, $index);
//
// if ($this->sphinx->Status() === false)
// {
// return array();
// }
//
// if (!$res || !isset($res["matches"]))
// {
// return array();
// }
//
// $ret = array();
// foreach ($res["matches"] as $match)
// $ret[] = $match['attrs']['keyword'];
//
// return $ret;
// }
protected function get_sugg_trigrams($word)
{
$trigrams = $this->BuildTrigrams($word);
$query = "\"$trigrams\"/1";
$len = strlen($word);
$this->sphinx->ResetGroupBy();
$this->sphinx->ResetFilters();
$this->sphinx->SetMatchMode(SPH_MATCH_EXTENDED2);
$this->sphinx->SetRankingMode(SPH_RANK_WORDCOUNT);
$this->sphinx->SetFilterRange("len", $len - 2, $len + 4);
$this->sphinx->SetSortMode(SPH_SORT_EXTENDED, "@weight DESC");
$this->sphinx->SetLimits(0, 10);
$params = phrasea::sbas_params($this->app);
$index_keys = array();
foreach ($params as $sbas_id => $p) {
if ( ! array_key_exists($sbas_id, $this->distinct_sbas))
continue;
$index_keys[] = crc32(str_replace(array('.', '%'), '_', sprintf('%s_%s_%s_%s', $p['host'], $p['port'], $p['user'], $p['dbname'])));
}
$index = 'suggest' . implode(',suggest', $index_keys);
$res = $this->sphinx->Query($query, $index);
if ($this->sphinx->Status() === false) {
return array();
}
if ( ! $res || ! isset($res["matches"])) {
return array();
}
$this->sphinx->ResetGroupBy();
$this->sphinx->ResetFilters();
$this->set_options($this->options);
$ret = array();
foreach ($res["matches"] as $match)
$ret[] = $match['attrs']['keyword'];
return $ret;
}
public function get_suggestions($I18n, $only_last_word = false)
{
if ( ! $this->current_index)
$this->current_index = '*';
$supposed_qry = mb_strtolower($this->query);
$pieces = explode(" ", str_replace(array("all", "last", "et", "ou", "sauf", "and", "or", "except", "in", "dans", "'", '"', "(", ")", "_", "-"), ' ', $supposed_qry));
$clef = 'sph_sugg_' . crc32(serialize($this->options) . ' ' . $this->current_index . implode(' ', $pieces) . ' ' . ($only_last_word ? '1' : '0'));
try {
return $this->app['phraseanet.appbox']->get_data_from_cache($clef);
} catch (Exception $e) {
}
$potential_queries = array();
$n = 0;
if ($only_last_word) {
$pieces = array(array_pop($pieces));
}
$tag = $I18n;
$suggestions = array();
$total_chaines = 0;
$propal_n = $this->get_total_results();
if (function_exists('enchant_broker_init')) {
$r = enchant_broker_init();
if (enchant_broker_dict_exists($r, $tag)) {
$d = enchant_broker_request_dict($r, $tag);
foreach ($pieces as $piece) {
if (trim($piece) === '')
continue;
$found = false;
$suggs = array($piece);
if (enchant_dict_check($d, $piece) == false) {
$suggs = array_unique(array_merge($suggs, enchant_dict_suggest($d, $piece)));
}
$suggestions[$n] = array('original' => $piece, 'suggs' => $suggs);
$n ++;
}
enchant_broker_free_dict($d);
}
enchant_broker_free($r);
}
if ($only_last_word) {
foreach ($pieces as $piece) {
foreach ($this->get_sugg_trigrams($piece) as $tri_sugg) {
$suggestions[$n] = array('original' => $piece, 'suggs' => array($tri_sugg));
$n ++;
}
}
}
$q_todo = array($supposed_qry);
$n = 0;
foreach ($suggestions as $suggestion) {
$tmp_qq = array();
foreach ($suggestion['suggs'] as $sugg) {
foreach ($q_todo as $q_td) {
$tmp_qq[] = $q_td;
$tmp_data = str_replace($suggestion['original'], $sugg, $q_td);
$tmp_qq[] = $tmp_data;
}
$tmp_qq[] = str_replace($suggestion['original'], $sugg, $supposed_qry);
}
$q_todo = array_unique(array_merge($tmp_qq, array($supposed_qry)));
$n ++;
}
$propals = array(
array(
'value' => $supposed_qry
, 'current' => true
, 'hits' => $this->get_total_results()
)
);
foreach ($q_todo as $f) {
if ($f == $supposed_qry)
continue;
$clef_unique_datas = 'sph_sugg_' . crc32(serialize($this->options) . $this->current_index . $f);
try {
$datas = $this->app['phraseanet.appbox']->get_data_from_cache($clef_unique_datas);
} catch (Exception $e) {
$datas = false;
}
if (is_int($datas)) {
$found = $datas;
$cache = true;
} else {
$cache = false;
$found = 0;
$tmp_res = $this->sphinx->Query($f, $this->current_index);
if ($tmp_res !== false && isset($tmp_res['total_found'])) {
$found = (int) $tmp_res['total_found'];
}
$this->app['phraseanet.appbox']->set_data_to_cache($found, $clef_unique_datas, 3600);
}
if ($found > 0) {
$propals[] = array(
'value' => $f
, 'current' => false
, 'hits' => $found
, 'cache' => $cache
);
}
}
usort($propals, array('self', 'suggestions_hit_sorter'));
$max = 0;
foreach ($propals as $key => $prop) {
$max = max($max, $prop['hits'] * 1 / 100);
if ($prop['hits'] < $max)
unset($propals[$key]);
}
$this->app['phraseanet.appbox']->set_data_to_cache($propals, $clef, 3600);
return $propals;
}
protected static function suggestions_hit_sorter($a, $b)
{
if ($a['hits'] == $b['hits']) {
return 0;
}
return ($a['hits'] > $b['hits']) ? -1 : 1;
}
/**
*
* @return string
*/
public function get_parsed_query()
{
return $this->query;
}
/**
*
* @param string $query
* @param array $fields
* @param int $selected_sbas_id
* @return array
*/
public function build_excerpt($query, array $fields, record_adapter $record)
{
$selected_sbas_id = $record->get_sbas_id();
$index = '';
$params = phrasea::sbas_params($this->app);
$index_keys = array();
foreach ($params as $sbas_id => $params) {
if ($sbas_id != $selected_sbas_id)
continue;
$index_keys[] = crc32(str_replace(array('.', '%'), '_', sprintf('%s_%s_%s_%s', $params['host'], $params['port'], $params['user'], $params['dbname'])));
}
if (count($index_keys) > 0) {
if ($this->search_in_field === false) {
$index = '';
$found = false;
if ($this->options->get_use_stemming()) {
if ($this->app['locale.I18n'] == 'fr') {
$index .= 'documents' . implode('_stemmed_fr, documents', $index_keys) . '_stemmed_fr';
$found = true;
} elseif ($this->app['locale.I18n'] == 'en') {
$index .= 'documents' . implode('_stemmed_en, documents', $index_keys) . '_stemmed_en';
$found = true;
}
}
if ( ! $found)
$index .= 'documents' . implode(', documents', $index_keys);
} else {
$index = '';
$found = false;
if ($this->options->get_use_stemming() && $this->app['locale.I18n'] == 'fr') {
if ($this->app['locale.I18n'] == 'fr') {
$index .= 'metadatas' . implode('_stemmed_fr, metadatas', $index_keys) . '_stemmed_fr';
$found = true;
} elseif ($this->app['locale.I18n'] == 'en') {
$index .= 'metadatas' . implode('_stemmed_en, metadatas', $index_keys) . '_stemmed_en';
$found = true;
}
}
if ( ! $found)
$index = 'metadatas' . implode(',metadatas', $index_keys);
}
}
$opts = array(
'before_match' => "<em>",
'after_match' => "</em>"
);
$fields_to_send = array();
foreach ($fields as $k => $f) {
$fields_to_send[$k] = $f['value'];
}
return $this->sphinx->BuildExcerpts($fields_to_send, $index, $query, $opts);
}
}

View File

@@ -1,464 +0,0 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
/**
*
* @package searchEngine
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
class searchEngine_options implements Serializable
{
const RECORD_RECORD = 0;
const RECORD_GROUPING = 1;
const TYPE_IMAGE = 'image';
const TYPE_VIDEO = 'video';
const TYPE_AUDIO = 'audio';
const TYPE_DOCUMENT = 'document';
const TYPE_FLASH = 'flash';
const TYPE_ALL = '';
const SORT_RELEVANCE = 'relevance';
const SORT_CREATED_ON = 'created_on';
const SORT_RANDOM = 'random';
const SORT_MODE_ASC = 'asc';
const SORT_MODE_DESC = 'desc';
/**
*
* @var string
*/
protected $record_type;
/**
*
* @var string
*/
protected $search_type = 0;
/**
*
* @var array
*/
protected $bases = array();
/**
*
* @var array
*/
protected $fields = array();
/**
*
* @var array
*/
protected $status = array();
/**
*
* @var DateTime
*/
protected $date_min;
/**
*
* @var DateTime
*/
protected $date_max;
/**
*
* @var array
*/
protected $date_fields = array();
/**
*
* @var string
*/
protected $i18n;
/**
*
* @var boolean
*/
protected $stemming = true;
/**
*
* @var string
*/
protected $sort_by;
/**
*
* @var string
*/
protected $sort_ord = self::SORT_MODE_DESC;
protected $business_fields = array();
/**
* Constructor
*
* @return searchEngine_options
*/
public function __construct()
{
return $this;
}
/**
*
* @param string $locale
*/
public function set_locale($locale)
{
$this->i18n = $locale;
}
/**
*
* @return string
*/
public function get_locale()
{
return $this->i18n;
}
/**
*
* @param const $sort_by
* @param const $sort_ord
* @return searchEngine_options
*/
public function set_sort($sort_by, $sort_ord = self::SORT_MODE_DESC)
{
$this->sort_by = $sort_by;
$this->sort_ord = $sort_ord;
return $this;
}
public function set_business_fields(Array $base_ids)
{
$this->business_fields = $base_ids;
return $this;
}
public function get_business_fields()
{
return $this->business_fields;
}
/**
*
* @return string
*/
public function get_sortby()
{
return $this->sort_by;
}
/**
*
* @return string
*/
public function get_sortord()
{
return $this->sort_ord;
}
/**
*
* @param boolean $boolean
* @return searchEngine_options
*/
public function set_use_stemming($boolean)
{
$this->stemming = ! ! $boolean;
return $this;
}
/**
*
* @return boolean
*/
public function get_use_stemming()
{
return $this->stemming;
}
/**
*
* @param int $search_type
* @return searchEngine_options
*/
public function set_search_type($search_type)
{
switch ($search_type) {
case self::RECORD_RECORD:
default:
$this->search_type = self::RECORD_RECORD;
break;
case self::RECORD_GROUPING:
$this->search_type = self::RECORD_GROUPING;
break;
}
return $this;
}
/**
*
* @return int
*/
public function get_search_type()
{
return $this->search_type;
}
/**
*
* @param array $base_ids
* @param ACL $ACL
* @return searchEngine_options
*/
public function set_bases(Array $base_ids, ACL $ACL)
{
foreach ($base_ids as $base_id) {
if ($ACL->has_access_to_base($base_id))
$this->bases[$base_id] = $base_id;
}
return $this;
}
/**
*
* @return array
*/
public function get_bases()
{
return $this->bases;
}
/**
*
* @param array $fields
* @return searchEngine_options
*/
public function set_fields(Array $fields)
{
$this->fields = $fields;
return $this;
}
/**
*
* @return array
*/
public function get_fields()
{
return $this->fields;
}
/**
*
* @param array $status
* @return searchEngine_options
*/
public function set_status(Array $status)
{
$tmp = array();
foreach ($status as $n => $options) {
if (count($options) > 1)
continue;
if (isset($options['on'])) {
foreach ($options['on'] as $sbas_id)
$tmp[$n][$sbas_id] = 1;
}
if (isset($options['off'])) {
foreach ($options['off'] as $sbas_id)
$tmp[$n][$sbas_id] = 0;
}
}
$this->status = $tmp;
return $this;
}
/**
*
* @return array
*/
public function get_status()
{
return $this->status;
}
/**
*
* @param string $record_type
* @return searchEngine_options
*/
public function set_record_type($record_type)
{
switch ($record_type) {
case self::TYPE_ALL:
default:
$this->record_type = self::TYPE_ALL;
break;
case self::TYPE_AUDIO:
$this->record_type = self::TYPE_AUDIO;
break;
case self::TYPE_VIDEO:
$this->record_type = self::TYPE_VIDEO;
break;
case self::TYPE_DOCUMENT:
$this->record_type = self::TYPE_DOCUMENT;
break;
case self::TYPE_FLASH:
$this->record_type = self::TYPE_FLASH;
break;
case self::TYPE_IMAGE:
$this->record_type = self::TYPE_IMAGE;
break;
}
return $this;
}
/**
*
* @return string
*/
public function get_record_type()
{
return $this->record_type;
}
/**
*
* @param string $min_date
* @return searchEngine_options
*/
public function set_min_date($min_date)
{
if ( ! is_null($min_date) && trim($min_date) !== '') {
$this->date_min = DateTime::createFromFormat('Y/m/d H:i:s', $min_date . ' 00:00:00');
}
return $this;
}
/**
*
* @return DateTime
*/
public function get_min_date()
{
return $this->date_min;
}
/**
*
* @param string $max_date
* @return searchEngine_options
*/
public function set_max_date($max_date)
{
if ( ! is_null($max_date) && trim($max_date) !== '') {
$this->date_max = DateTime::createFromFormat('Y/m/d H:i:s', $max_date . ' 23:59:59');
}
return $this;
}
/**
*
* @return DateTime
*/
public function get_max_date()
{
return $this->date_max;
}
/**
*
* @param array $fields
* @return searchEngine_options
*/
public function set_date_fields(Array $fields)
{
$this->date_fields = $fields;
return $this;
}
/**
*
* @return array
*/
public function get_date_fields()
{
return $this->date_fields;
}
/**
*
* @return string
*/
public function serialize()
{
$ret = array();
foreach ($this as $key => $value) {
if ($value instanceof DateTime)
$value = $value->format('d-m-Y h:i:s');
$ret[$key] = $value;
}
return p4string::jsonencode($ret);
}
/**
*
* @param string $serialized
* @return searchEngine_options
*/
public function unserialize($serialized)
{
$serialized = json_decode($serialized);
foreach ($serialized as $key => $value) {
if (is_null($value)) {
$value = null;
} elseif (in_array($key, array('date_min', 'date_max'))) {
$value = new DateTime($value);
} elseif ($value instanceof stdClass) {
$tmpvalue = (array) $value;
$value = array();
foreach ($tmpvalue as $k => $data) {
$k = ctype_digit($k) ? (int) $k : $k;
$value[$k] = $data;
}
}
$this->$key = $value;
}
return $this;
}
}

View File

@@ -1,144 +0,0 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
/**
*
* @package searchEngine
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
class searchEngine_results
{
/**
*
* @var set
*/
protected $result;
/**
*
* @var searchEngine_adapter_interface
*/
protected $engine;
/**
*
* @param set $result
* @param searchEngine_adapter_interface $engine
* @return searchEngine_results
*/
public function __construct(set_abstract $result, searchEngine_adapter_interface $engine)
{
$this->engine = $engine;
$this->result = $result;
return $this;
}
/**
*
* @return set
*/
public function get_datas()
{
return $this->result;
}
/**
*
* @return float
*/
public function get_query_time()
{
return $this->engine->get_time();
}
/**
*
* @return int
*/
public function get_total_pages()
{
return $this->engine->get_total_pages();
}
/**
*
* @return int
*/
public function get_current_page()
{
return (int) $this->engine->get_current_page();
}
/**
*
* @return int
*/
public function get_count_available_results()
{
return (int) $this->engine->get_available_results();
}
/**
*
* @return int
*/
public function get_count_total_results()
{
return (int) $this->engine->get_total_results();
}
/**
*
* @return string
*/
public function get_error()
{
return $this->engine->get_error();
}
/**
*
* @return string
*/
public function get_warning()
{
return $this->engine->get_warning();
}
/**
*
* @return array
*/
public function get_suggestions($I18n)
{
return $this->engine->get_suggestions($I18n);
}
/**
*
* @return string
*/
public function get_propositions()
{
return $this->engine->get_propositions();
}
/**
*
* @return string
*/
public function get_search_indexes()
{
return $this->engine->get_current_indexes();
}
}

View File

@@ -1,29 +0,0 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
/**
*
*
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
class set_result extends set_abstract
{
/**
*
* @return set_result
*/
public function __construct()
{
return $this;
}
}

View File

@@ -1,241 +0,0 @@
<?php
require_once __DIR__ . '/PhraseanetPHPUnitAuthenticatedAbstract.class.inc';
class searchEngine_optionsTest extends PhraseanetPHPUnitAuthenticatedAbstract
{
/**
* @var searchEngine_options
*/
protected $object;
public function setUp()
{
parent::setUp();
$this->object = new searchEngine_options();
}
public function testSet_locale()
{
$locale = 'BABA';
$this->object->set_locale($locale);
$this->assertEquals($locale, $this->object->get_locale());
}
public function testGet_locale()
{
$locale = null;
$this->object->set_locale($locale);
$this->assertEquals($locale, $this->object->get_locale());
}
public function testSet_sort()
{
$by = 'NAME';
$sort = 'ASC';
$this->object->set_sort($by, $sort);
$this->assertEquals($by, $this->object->get_sortby());
$this->assertEquals($sort, $this->object->get_sortord());
$this->object->set_sort($by);
$this->assertEquals($by, $this->object->get_sortby());
$this->assertEquals(searchEngine_options::SORT_MODE_DESC, $this->object->get_sortord());
}
public function testGet_sortby()
{
$by = 'NAME';
$sort = 'DESC';
$this->object->set_sort($by, $sort);
$this->assertEquals($by, $this->object->get_sortby());
$this->assertEquals($sort, $this->object->get_sortord());
}
public function testGet_sortord()
{
$by = 'NAME';
$sort = 'DESC';
$this->object->set_sort($by, $sort);
$this->assertEquals($by, $this->object->get_sortby());
$this->assertEquals($sort, $this->object->get_sortord());
}
public function testSet_use_stemming()
{
$bool = true;
$this->object->set_use_stemming($bool);
$this->assertEquals($bool, $this->object->get_use_stemming());
$bool = false;
$this->object->set_use_stemming($bool);
$this->assertEquals($bool, $this->object->get_use_stemming());
}
public function testGet_use_stemming()
{
$bool = true;
$this->object->set_use_stemming($bool);
$this->assertEquals($bool, $this->object->get_use_stemming());
$bool = false;
$this->object->set_use_stemming($bool);
$this->assertEquals($bool, $this->object->get_use_stemming());
}
public function testSet_search_type()
{
$type = "caca";
$this->object->set_search_type($type);
$this->assertEquals(searchEngine_options::RECORD_RECORD, $this->object->get_search_type());
$type = searchEngine_options::RECORD_RECORD;
$this->object->set_search_type($type);
$this->assertEquals(searchEngine_options::RECORD_RECORD, $this->object->get_search_type());
$type = searchEngine_options::RECORD_GROUPING;
$this->object->set_search_type($type);
$this->assertEquals(searchEngine_options::RECORD_GROUPING, $this->object->get_search_type());
}
public function testGet_search_type()
{
$type = "caca";
$this->object->set_search_type($type);
$this->assertEquals(searchEngine_options::RECORD_RECORD, $this->object->get_search_type());
$type = searchEngine_options::RECORD_RECORD;
$this->object->set_search_type($type);
$this->assertEquals(searchEngine_options::RECORD_RECORD, $this->object->get_search_type());
$type = searchEngine_options::RECORD_GROUPING;
$this->object->set_search_type($type);
$this->assertEquals(searchEngine_options::RECORD_GROUPING, $this->object->get_search_type());
}
public function testSet_bases()
{
$bases = array_keys(self::$DI['user']->ACL()->get_granted_base());
$this->object->set_bases($bases, self::$DI['user']->ACL());
$this->assertEquals(array_values($bases), array_values($this->object->get_bases()));
}
public function testGet_bases()
{
$bases = array_keys(self::$DI['user']->ACL()->get_granted_base());
$this->object->set_bases($bases, self::$DI['user']->ACL());
$this->assertEquals(array_values($bases), array_values($this->object->get_bases()));
}
public function testSet_fields()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testGet_fields()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testSet_status()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testGet_status()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testSet_record_type()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testGet_record_type()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testSet_min_date()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testGet_min_date()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testSet_max_date()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testGet_max_date()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testSet_date_fields()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testGet_date_fields()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
public function testSerialize()
{
$bases = array_keys(self::$DI['user']->ACL()->get_granted_base());
$this->object->set_bases($bases, self::$DI['user']->ACL());
$this->object->set_date_fields(array());
$this->object->set_locale('fr_FR');
$this->object->set_max_date(null);
$this->object->set_min_date(null);
$this->object->set_record_type(searchEngine_options::TYPE_AUDIO);
$this->object->set_search_type(searchEngine_options::RECORD_RECORD);
$this->object->set_sort('Name', 'DESC');
$this->object->set_status(array());
$this->object->set_use_stemming(true);
$this->assertEquals($this->object, unserialize(serialize($this->object)));
}
public function testUnserialize()
{
// Remove the following lines when you implement this test.
$this->markTestIncomplete(
'This test has not been implemented yet.'
);
}
}