api-platform hydra:totalItems的全局groupBy过滤器/扩展有问题
创始人
2024-09-07 04:30:42
0

当使用API-Platform和Hydra:totalItems进行全局groupBy过滤器/扩展时,可能会出现一些问题。下面是一个可能的解决方法,其中包含代码示例:

  1. 确保在你的实体类(例如User)中定义了正确的groupBy注解。例如,如果你想按照用户的地理位置进行分组,可以这样定义:
use ApiPlatform\Core\Annotation\ApiProperty;
use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Entity
 */
class User
{
    // ...

    /**
     * @ORM\Column(type="string")
     * @ApiProperty(identifier=true)
     */
    private $id;

    // ...

    /**
     * @ORM\Column(type="string")
     * @ApiProperty(
     *     attributes={
     *         "swagger_context"={
     *             "type"="string",
     *             "description"="Group by location"
     *         }
     *     }
     * )
     */
    private $location;

    // ...
}
  1. 在你的API资源类(例如UserResource)中,定义一个自定义的数据提供器(DataProvider)来处理groupBy过滤器/扩展。你可以使用Doctrine ORM来执行特定的查询。例如:
use ApiPlatform\Core\DataProvider\ContextAwareCollectionDataProviderInterface;
use ApiPlatform\Core\DataProvider\RestrictedDataProviderInterface;
use Doctrine\ORM\EntityManagerInterface;
use Doctrine\ORM\Query\Expr\GroupBy;
use Doctrine\ORM\QueryBuilder;

class UserDataProvider implements ContextAwareCollectionDataProviderInterface, RestrictedDataProviderInterface
{
    private $entityManager;

    public function __construct(EntityManagerInterface $entityManager)
    {
        $this->entityManager = $entityManager;
    }

    public function supports(string $resourceClass, string $operationName = null, array $context = []): bool
    {
        return User::class === $resourceClass && null === $operationName;
    }

    public function getCollection(string $resourceClass, string $operationName = null, array $context = []): iterable
    {
        // 获取groupBy参数
        $groupBy = $context['filters']['hydra:totalItems']['groupBy'] ?? null;
        if (null === $groupBy) {
            return [];
        }

        // 执行查询
        $queryBuilder = $this->entityManager->createQueryBuilder();
        $queryBuilder->select('u')->from(User::class, 'u')->groupBy('u.' . $groupBy);
        $query = $queryBuilder->getQuery();
        $results = $query->getResult();

        return $results;
    }
}
  1. 在你的服务配置文件(例如services.yaml)中,将自定义的数据提供器添加为服务:
services:
    App\DataProvider\UserDataProvider:
        arguments:
            - '@doctrine.orm.entity_manager'
  1. 最后,在你的API资源类中,将自定义的数据提供器应用到对应的操作中。例如:
use ApiPlatform\Core\Annotation\ApiResource;

/**
 * @ApiResource(
 *     collectionOperations={
 *         "get"={
 *             "method"="GET",
 *             "path"="/users",
 *             "controller"=UserDataProvider::class,
 *             "defaults"={
 *                 "_api_receive"=false,
 *                 "_api_respond"=true
 *             }
 *         }
 *     },
 *     itemOperations={},
 *     shortName="User"
 * )
 */
class UserResource
{
    // ...
}

通过执行以上步骤,你应该能够使用API-Platform和Hydra:totalItems的全局groupBy过滤器/扩展,并正确地获取分组后的结果。

相关内容

热门资讯

每日必备(Wepoke德州)外... Wepoke德州赢率提升策略‌;每日必备(Wepoke德州)外挂透明挂辅助APP(辅助挂)透视辅助(...
分享一款(Wepoke合作)外... 分享一款(Wepoke合作)外挂透明挂辅助器安装(辅助挂)软件透明挂(2023已更新)(哔哩哔哩);...
透明私人局!WPK线上(weP... 透明私人局!WPK线上(wePOke)外挂透明挂辅助器安装(透视)力荐教程(今日头条)-哔哩哔哩;1...
透视辅助(德扑之星ai代打)外... 透视辅助(德扑之星ai代打)外挂透明挂辅助工具(透视)透视辅助(有挂分享)-哔哩哔哩是一款可以让一直...
热点推荐(眯眯扑克)外挂透明挂... WePoker透视辅助工具核心要点解析‌,热点推荐(眯眯扑克)外挂透明挂辅助脚本(辅助挂)辅助透视(...
玩家攻略推荐!Wepoke工具... 玩家攻略推荐!Wepoke工具(wepoke)外挂透明挂辅助工具(辅助挂)德州论坛(有挂技术)-哔哩...
终于清楚(WPK透视挂)外挂透... 1、终于清楚(WPK透视挂)外挂透明挂辅助app(透视)发牌规律(真是有挂)-哔哩哔哩(UU pok...
2024教程(德扑安装)外挂透... 2024教程(德扑安装)外挂透明挂辅助脚本(辅助挂)软件透明挂(2021已更新)(哔哩哔哩);支持多...
我来分享!Wepoke测试(w... 我来分享!Wepoke测试(wEpoKe)外挂透明挂辅助APP(辅助挂)插件教程(有挂方式)-哔哩哔...
交流学习经验(德州alphax... 交流学习经验(德州alphax)外挂透明挂辅助脚本(透视)软件透明挂(有挂工具)-哔哩哔哩关于德州a...