Symfony2 - 使用 Doctrine 存储库的选择约束

Symfony2 - choice constraint using Doctrine repository

我有一个实体,我想根据数据库查询验证其中一个属性。我在我的存储库中将其定义为一种方法,例如:

class EntryRepository extends EntityRepository {

    /**
     * Gets valid entries for validation
     */
    public function getValidEntries() {
        return $this->createQueryBuilder('s')
            ->where('s.isAvailable = :isAvailable')
            ->setParameter('isAvailable', true)
            ->getQuery()
            ->getResult();
    }

    ...
}

我如何使用它为选择约束提供可用的选择?我可以在我的实体 class 中这样定义它:

use Symfony\Component\Validator\Constraints as Assert;

class SomeEntity {

    /**
     * @Assert\Choice(callback = {"Acme\MyBundle\Entity\EntryRepository", "getValidEntries"})
     * ...
     */
    private $entry;

    ...

    }

但是,这需要我在存储库中将此方法设为静态,这不是定义存储库方法的好方法。

有没有办法正确地做到这一点?或者也许我正在尝试重新发明轮子,并且有更好的方法来完成我在这里尝试做的事情?

好吧,我打算按照 Cerad 的建议创建自定义验证约束,但我想出了一些更简单的方法 - Callback constraint

use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Component\Validator\Context\ExecutionContextInterface;
use Acme\MyBundle\Entity\Entry;

class SomeEntity {

    /**
     * @var Entry
     */
    private $entry;

    ...

    /**
     * @Assert\Callback
     */
    public function validate(ExecutionContextInterface $context) {
        if (!$this->entry->isAvailable()) {
            $context
            ->buildViolation('Entry is not available')
            ->addViolation();
        }
    }

}