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过滤器/扩展,并正确地获取分组后的结果。

相关内容

热门资讯

透视插件!wepoker可以设... 透视插件!wepoker可以设置盖牌-关于开挂透视辅助教程(有挂教学)透视插件!wepoker可以设...
最新技巧“浙江游戏大厅修改器”... 最新技巧“浙江游戏大厅修改器”原先有开挂辅助挂(确实有挂);1、这是跨平台的浙江游戏大厅修改器黑科技...
透视挂透视!hhpoker可以... 透视挂透视!hhpoker可以开挂-揭露开挂透视辅助攻略(有挂攻略)1、hhpoker可以开挂系统规...
玩家必看分享“小程序微乐游戏辅... 玩家必看分享“小程序微乐游戏辅助器”其实有开挂辅助器(详细教程);1、让任何用户在无需AI插件第三方...
透视工具!wepoker国外版... 透视工具!wepoker国外版透视-教你开挂透视辅助工具(了解有挂)1、全新机制【wepoker国外...
专业讨论“欢乐游戏城破解版内置... 专业讨论“欢乐游戏城破解版内置修改器”本来有开挂辅助脚本(了解有挂);详细欢乐游戏城破解版内置修改器...
一分钟教你“宝宝游戏辅助”好像... 您好:宝宝游戏辅助这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别...
透视最新!hhpoker透视挂... 透视最新!hhpoker透视挂实战视频-解谜开挂透视辅助攻略(有挂技术)1、超多福利:超高返利,海量...
9分钟了解“四川家园游戏辅助器... 9分钟了解“四川家园游戏辅助器平台交易”果然有开挂辅助下载(有挂规律);亲真的是有正版授权,小编(透...
透视科技!wepoker智能辅... 透视科技!wepoker智能辅助插件-教你开挂透视辅助插件(有挂方针)1、进入到wepoker智能辅...