我正在构建一个 RESTful API,但我有问题。
目标:我想为来自分页器的集合补水。我的意思是,在集合中,我不想返回项目对象,我想返回 HalResources 的 HalCollection。要创建这些 HalResources,我需要使用 Project 对象(以及其他信息)。
场景:我创建了一个类ProjectHydrator,它使用两种方法实现HydratorInterface:
class ProjectHydrator implements HydratorInterface {
public function hydrate(array $data, $project){ .... }
public function extract($project) { .... }
}
我将这个水合器连接到我的模块,在模块.config内.php
'phlyrestfully' => array (
'renderer' => array (
'hydrators' => array (
'MYPROJECTEntityProject' => new MYPROJECTHydratorsProjectHydrator()
)
),
......
)
并且 fetchAll 侦听器方法 y 以这种方式创建分页:
$dql = 'SELECT e FROM MYPROJECTEntityProject e';
$query = $this->getEntityManager()->createQuery($dql); // Class: DoctrineORMQuery
$ormPaginator = new DoctrineORMToolsPaginationPaginator($query); //Class: DoctrineORMToolsPaginationPaginator
$doctrinePaginator = new DoctrineORMModulePaginatorAdapterDoctrinePaginator($ormPaginator); //Class: DoctrineORMModulePaginatorAdapterDoctrinePaginator
$paginator = new ZendPaginatorPaginator($doctrinePaginator); //Class: ZendPaginatorPaginator
return $paginator;
问题:水化器正在执行...但称为方法"提取",参数为 Project 对象。在这种方法中,我必须返回和数组,这是我的问题,我想返回一个 HalResource,而不是数组。
我想使用水化器将对象的类型从项目对象(项目实体对象)更改为 HalResource。为了构建这个 HalResource,我想使用 Project 对象和一个带有其他参数的数组。
我做错了什么?有什么想法吗?
谢谢!
无需扩展Doctrine Paginator
,只需将查询水合模式设置为水合数组模式即可。
use DoctrineORMQuery;
use DoctrineORMToolsPaginationPaginator as DoctrinePaginator;
use DoctrineORMModulePaginatorAdapterDoctrinePaginator as PaginatorAdapter;
use ZendPaginatorPaginator;
$dql = 'SELECT e FROM MYPROJECTEntityProject e';
$query = $this->getEntityManager()->createQuery($dql);
//Set query hydration mode
$query->setHydrationMode(Query::HYDRATE_ARRAY);
$paginator = new Paginator(new PaginatorAdapter(new DoctrinePaginator($query)));
return $paginator;
希望对您有所帮助。