mirror of
https://github.com/retailcrm/NelmioApiDocBundle.git
synced 2025-02-02 15:51:48 +03:00
cca97cf6af
Move logic to extract data in the Extractor Remove logic in the AbstractFormatter Use ApiDoc class as data container Update tests Add test to prove the bug with FOSRestBundle annotations (\\d+ instead of \d+)
55 lines
1.2 KiB
PHP
55 lines
1.2 KiB
PHP
<?php
|
||
|
||
/*
|
||
* This file is part of the NelmioApiDocBundle.
|
||
*
|
||
* (c) Nelmio <hello@nelm.io>
|
||
*
|
||
* For the full copyright and license information, please view the LICENSE
|
||
* file that was distributed with this source code.
|
||
*/
|
||
|
||
namespace Nelmio\ApiDocBundle\Formatter;
|
||
|
||
use Nelmio\ApiDocBundle\Annotation\ApiDoc;
|
||
|
||
abstract class AbstractFormatter implements FormatterInterface
|
||
{
|
||
/**
|
||
* {@inheritdoc}
|
||
*/
|
||
public function formatOne(ApiDoc $annotation)
|
||
{
|
||
return $this->renderOne($annotation->toArray());
|
||
}
|
||
|
||
/**
|
||
* {@inheritdoc}
|
||
*/
|
||
public function format(array $collection)
|
||
{
|
||
$array = array();
|
||
foreach ($collection as $coll) {
|
||
$array[$coll['resource']][] = $coll['annotation']->toArray();
|
||
}
|
||
|
||
return $this->render($array);
|
||
}
|
||
|
||
/**
|
||
* Format a single array of data
|
||
*
|
||
* @param array $data
|
||
* @return string|array
|
||
*/
|
||
abstract protected function renderOne(array $data);
|
||
|
||
/**
|
||
* Format a set of resource sections.
|
||
*
|
||
* @param array $collection
|
||
* @return string|array
|
||
*/
|
||
abstract protected function render(array $collection);
|
||
}
|