Implementing search language

refs #223
This commit is contained in:
2014-12-27 18:59:56 +01:00
parent d59882159d
commit 13f7dcb00b
4 changed files with 126 additions and 12 deletions

View File

@@ -0,0 +1,6 @@
<?php
namespace Chill\MainBundle\Search;
class ParsingException extends \Exception
{
}

View File

@@ -31,7 +31,7 @@ namespace Chill\MainBundle\Search;
*/
interface SearchInterface #-> good name ?
{
/*
/**
* return the result in a html string. The string will be inclued (as raw)
* into a global view.
*
@@ -40,15 +40,15 @@ interface SearchInterface #-> good name ?
* {{ result|raw }}
* {% endfor %}
*
* @param string $pattern the string to search
* @param array $terms the string to search
* @param int $start the first result (for pagination)
* @param int $limit the number of result (for pagination)
* @param array $option the options, specific for each search
* @return string, an HTML string
*/
public function renderResult($pattern, $start=0, $limit=50, array $options = array());
public function renderResult($terms, $start=0, $limit=50, array $options = array());
/*
/**
* we may desactive the search interface by default. in this case,
* the search will be launch and rendered only with "advanced search"
*
@@ -58,14 +58,7 @@ interface SearchInterface #-> good name ?
*/
public function isActiveByDefault();
/*
* a string used in advanced search to activate the search
*
* @return string a string which will be translated by twig
*/
public function getLabel();
/*
/**
* the order in which the results will appears in the global view
*
* (this may be eventually defined in config.yml)
@@ -73,4 +66,12 @@ interface SearchInterface #-> good name ?
* @return int
*/
public function getOrder();
/**
* indicate if the implementation supports the given domain
*
* @return boolean
*/
public function supports($domain);
}

View File

@@ -39,6 +39,55 @@ class SearchProvider
return $this->searchServices;
}
/**
* parse the search string to extract domain and terms
*
* @param string $pattern
* @return string[] an array where the keys are _domain, _default (residual terms) or term
*/
public function parse($pattern)
{
$terms = array();
$terms['_domain'] = $this->getDomain($pattern);
return $terms;
}
private function getDomain($subject)
{
preg_match_all( '/@([a-z]+)/', $subject, $terms);
if (count($terms[0]) > 1) {
throw new ParsingException('You should not have more than one domain');
}
return isset($terms[1][0]) ? $terms[1][0] : '';
}
/**
* search through services which supports domain and give
* results as html string
*
* @param string $pattern
* @param number $start
* @param number $limit
* @return array of html results
*/
public function getResults($pattern, $start = 0, $limit = 50)
{
$terms = $this->parse($pattern);
$results = array();
foreach ($searchServices as $service) {
if ($service->supports($terms['_domain'])) {
$results[] = $service->renderResult($terms, $start, $limit);
}
}
return $results;
}
/*
* return search services with a specific name, defined in service