Files
afup/sources/AppBundle/Event/Model/HydratorAggregator.php
Adrien Gallou 837423eede correction retour de l'hydrator si la requête ne renvoie aucun résultat
si la requête ne renvoyait aucun résultat on yieldait tout de même
des tableaux vides/incomplets ce qui pouvait causer des erreurs 500.
2019-06-30 18:14:16 +02:00

149 lines
4.0 KiB
PHP

<?php
/***********************************************************************
*
* Ting - PHP Datamapper
* ==========================================
*
* Copyright (C) 2014 CCM Benchmark Group. (http://www.ccmbenchmark.com)
*
***********************************************************************
*
* Licensed under the Apache License, Version 2.0 (the "License"); you
* may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied. See the License for the specific language governing
* permissions and limitations under the License.
*
**********************************************************************/
namespace AppBundle\Event\Model;
use CCMBenchmark\Ting\Repository\Hydrator;
class HydratorAggregator extends Hydrator
{
/**
* @var callable
*/
protected $callableForId;
/**
* @var callable
*/
protected $callableForData;
/**
* @var callable
*/
protected $callableFinalizeAggregate;
/**
* @param callable $callableForId
* @return $this
*/
public function callableIdIs(callable $callableForId)
{
$this->callableForId = $callableForId;
return $this;
}
/**
* @param callable $callableForData
* @return $this
*/
public function callableDataIs(callable $callableForData)
{
$this->callableForData = $callableForData;
return $this;
}
/**
* @param callable $callableFinalizeAggregate
* @return $this
*/
public function callableFinalizeAggregate(callable $callableFinalizeAggregate)
{
$this->callableFinalizeAggregate = $callableFinalizeAggregate;
return $this;
}
/**
* @return \Generator
*/
public function getIterator()
{
$knownIdentifiers = [];
$callableForId = $this->callableForId;
$callableForData = $this->callableForData;
$previousId = null;
$previousResult = null;
$previousKey = null;
$currentId = null;
$aggregate = [];
$key = null;
$result = null;
foreach ($this->result as $key => $columns) {
$result = $this->hydrateColumns(
$this->result->getConnectionName(),
$this->result->getDatabase(),
$columns
);
$currentId = $callableForId($result);
if (isset($knownIdentifiers[$currentId]) === true) {
continue;
}
if ($previousId === null) {
$previousId = $currentId;
$previousResult = $result;
$previousKey = $key;
}
if ($previousId === $currentId) {
$aggregate[] = $callableForData($result);
} else {
$previousResult = $this->finalizeAggregate($previousResult, $aggregate);
$knownIdentifiers[$previousId] = true;
yield $previousKey => $previousResult;
$aggregate = [$callableForData($result)];
$previousId = $currentId;
$previousResult = $result;
$previousKey = $key;
}
}
if ($previousId === $currentId && $previousId !== null) {
yield $key => $this->finalizeAggregate($result, $aggregate);
}
}
/**
* @param mixed $result
* @param mixed $aggregate
*
* @return mixed
*/
private function finalizeAggregate($result, $aggregate)
{
if ($this->callableFinalizeAggregate === null) {
$result['aggregate'] = $aggregate;
return $result;
}
$callableFinalizeAggregate = $this->callableFinalizeAggregate;
return $callableFinalizeAggregate($result, $aggregate);
}
}