Merge remote-tracking branch 'origin/2.0'

This commit is contained in:
Jeremy Mikola 2012-02-25 17:41:18 -05:00
commit 7a9255a9ed
5 changed files with 72 additions and 1 deletions

View file

@ -2,6 +2,7 @@
namespace FOQ\ElasticaBundle\Doctrine;
use FOQ\ElasticaBundle\HybridResult;
use FOQ\ElasticaBundle\Transformer\ElasticaToModelTransformerInterface;
use Elastica_Document;
@ -84,6 +85,18 @@ abstract class AbstractElasticaToModelTransformer implements ElasticaToModelTran
return $objects;
}
public function hybridTransform(array $elasticaObjects)
{
$objects = $this->transform($elasticaObjects);
$result = array();
for ($i = 0; $i < count($elasticaObjects); $i++) {
$result[] = new HybridResult($elasticaObjects[$i], $objects[$i]);
}
return $result;
}
/**
* Fetches objects by theses identifier values
*

View file

@ -32,6 +32,20 @@ class TransformedFinder implements FinderInterface, PaginatedFinderInterface
* @return array of model objects
**/
public function find($query, $limit = null)
{
$results = $this->search($query, $limit);
return $this->transformer->transform($results);
}
public function findHybrid($query, $limit = null)
{
$results = $this->search($query, $limit);
return $this->transformer->hybridTransform($results);
}
protected function search($query, $limit = null)
{
$queryObject = Elastica_Query::create($query);
if (null !== $limit) {
@ -39,9 +53,10 @@ class TransformedFinder implements FinderInterface, PaginatedFinderInterface
}
$results = $this->searchable->search($queryObject)->getResults();
return $this->transformer->transform($results);
return $results;
}
/**
* Gets a paginator wrapping the result of a search
*

27
HybridResult.php Normal file
View file

@ -0,0 +1,27 @@
<?php
namespace FOQ\ElasticaBundle;
use Elastica_Result;
class HybridResult
{
protected $result;
protected $transformed;
public function __construct(Elastica_Result $result, $transformed = null)
{
$this->result = $result;
$this->transformed = $transformed;
}
public function getTransformed()
{
return $this->transformed;
}
public function getResult()
{
return $this->result;
}
}

View file

@ -2,6 +2,8 @@
namespace FOQ\ElasticaBundle\Transformer;
use FOQ\ElasticaBundle\HybridResult;
/**
* Holds a collection of transformers for an index wide transformation.
*
@ -56,6 +58,18 @@ class ElasticaToModelTransformerCollection implements ElasticaToModelTransformer
return $transformed;
}
public function hybridTransform(array $elasticaObjects)
{
$objects = $this->transform($elasticaObjects);
$result = array();
for ($i = 0; $i < count($elasticaObjects); $i++) {
$result[] = new HybridResult($elasticaObjects[$i], $objects[$i]);
}
return $result;
}
protected function getTypeToClassMap()
{
return array_map(function ($transformer) {

View file

@ -16,6 +16,8 @@ interface ElasticaToModelTransformerInterface
**/
function transform(array $elasticaObjects);
function hybridTransform(array $elasticaObjects);
/**
* Returns the object class used by the transformer.
*