1

我有一个选择字段(下拉列表),我想针对数据库表进行验证。

本质上,如果该值在查询结果中,则它是有效的。

我不太清楚 Symfony 指南中报告的回调是如何工作的 :(

但是,我有一个validation.yml文件:

User\UserBundle\Entity\Group:
    properties:
        role:
            - Choice:
                groups: [signUp]
                callback: [User\UserBundle\Entity\Group, getRoles]

实体Group.php

class Group
{
    /** @var int */
    private $id;

    //...

    public static function GetRoles()
    {
        return ['admin', 'user'];
    }
}

此示例运行良好,但是当我尝试从组存储库中获取这些值时出现问题GroupRepository.php

class GroupRepository extends EntityRepository
{
    public function getRoles()
    {
        return $this->createQueryBuilder('r')
            ->getQuery()
            ->getResult();
    }
}

在这个阶段我应该做什么?我使用的方法是否正确,还是应该直接在 中调用 Group Repository validation.yml?还是我完全走投无路?

4

1 回答 1

1

据我了解,您正在尝试从存储库中获取这些选项,例如:

...
callback: [User\UserBundle\Repository\GroupRepository, getRoles]

这不起作用,因为存储库需要通过 Doctrine ORM 服务进行初始化。

我猜你必须创建一个自定义的 Constraint 类和 ConstraintValidator,后者被配置为服务并获取作为参数传递的实体管理器。

请参阅http://symfony.com/doc/current/validation/custom_constraint.html

于 2017-09-12T17:57:43.443 回答