我有一个patner,一个买家和一个继承用户类的管理类
当我想添加合作伙伴时,验证器不起作用
* @DoctrineAssert\UniqueEntity(fields="username", message="Ce nom d'utilisateur est déjà utilisé, veuillez en choisir un autre.", groups={"registration", "account"})
* @DoctrineAssert\UniqueEntity(fields="mail", message="Cette adresse mail est déjà utilisé, veuillez en choisir un autre.", groups={"registration", "account"})
如果我为"合作伙伴选择用户名"已经在数据库中,它向我显示正确的验证错误。但是,如果我选择"买家的用户名"已存在于数据库中,没有验证,并且在我的数据库中存在唯一的字段错误。
班级用户
<?php
namespace Antho\Test\CoreBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Bridge\Doctrine\Validator\Constraints as DoctrineAssert;
use Symfony\Component\Security\Core\User\UserInterface;
use Symfony\Component\Security\Core\Encoder\MessageDigestPasswordEncoder;
/**
* Antho\Test\CoreBundle\Entity\User
*
* @ORM\Table(name="user")
* @ORM\Entity(repositoryClass="Antho\Test\CoreBundle\Entity\UserRepository")
* @ORM\InheritanceType("SINGLE_TABLE")
* @ORM\DiscriminatorColumn(name="type", type="string")
* @ORM\DiscriminatorMap({"user" = "User", "partner" = "Partner", "buyer" = "Buyer", "admin" = "Admin"})
* @ORM\HasLifecycleCallbacks()
* @DoctrineAssert\UniqueEntity(fields="username", message="Ce nom d'utilisateur est déjà utilisé, veuillez en choisir un autre.", groups={"registration", "account"})
* @DoctrineAssert\UniqueEntity(fields="mail", message="Cette adresse mail est déjà utilisé, veuillez en choisir un autre.", groups={"registration", "account"})
*/
class User implements UserInterface
{
/**
* @var integer $id
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string $username
*
* @ORM\Column(name="username", type="string", length=255, unique=true)
*/
private $username;
/**
* @var string $lastName
*
* @ORM\Column(name="last_name", type="string", length=255)
*/
private $lastName;
/**
* @var string $firstName
*
* @ORM\Column(name="first_name", type="string", length=255)
*/
private $firstName;
/**
* @var string $mail
*
* @ORM\Column(name="mail", type="string", length=255, unique=true)
*/
private $mail;
/**
* @var string $password
*
* @ORM\Column(name="password", type="string", length=255)
*/
private $password;
public function __construct()
{
if ($this->createdAt === null) {
$this->createdAt = new \DateTime('now');
}
$this->isEnabled = true;
}
public function __toString()
{
return $this->username;
}
GETTER and SETTER ...
}
班级合作伙伴
<?php
namespace Antho\Test\CoreBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Bridge\Doctrine\Validator\Constraints as DoctrineAssert;
/**
* Antho\Test\CoreBundle\Entity\Partner
*
* @ORM\Table(name="partner")
* @ORM\Entity(repositoryClass="Antho\Test\CoreBundle\Entity\PartnerRepository")
*/
class Partner extends User
{
/**
* @ORM\OneToMany(targetEntity="Restaurant", mappedBy="partner", cascade={"remove", "persist"})
*/
private $restaurants;
/**
* @var string $company
*
* @ORM\Column(name="company", type="string", length=255)
*/
private $company;
public function __construct()
{
parent::__construct();
$this->restaurants = new \Doctrine\Common\Collections\ArrayCollection();
$this->isValid = false;
}
GETTER and SETTER ...
}
类买家
<?php
namespace Antho\Test\CoreBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Bridge\Doctrine\Validator\Constraints as DoctrineAssert;
/**
* Antho\Test\CoreBundle\Entity\Buyer
*
* @ORM\Table(name="buyer")
* @ORM\Entity(repositoryClass="Antho\Test\CoreBundle\Entity\BuyerRepository")
*/
class Buyer extends User
{
/**
* @var string $address
*
* @ORM\Column(name="address", type="string", length=255)
*/
private $address;
/**
* @var string $city
*
* @ORM\Column(name="city", type="string", length=255)
*/
private $city;
/**
* @var string $zip
*
* @ORM\Column(name="zip", type="string", length=255)
*/
private $zip;
/**
* @var boolean $newsletter
*
* @ORM\Column(name="newsletter", type="boolean")
*/
private $newsletter;
public function __construct()
{
parent::__construct();
if ($this->newsletter === null) {
$this->newsletter = false;
}
}
GETTER and SETTER ...
}
答案 0 :(得分:1)
我的两分钱。不要假装是正确的答案。
从子类中删除所有不需要的@Table
并使字段可见(protected
)。我做了完全相同的(使用Symfony 2.0.x),它就像一个魅力。
它与您的代码略有不同,此处标记(或关键字)名称对每个用户都是唯一的。但无论如何你都可以测试它:
/**
* @ORM\Entity
* @ORM\Table(
* name="meta",
* uniqueConstraints={
* @ORM\UniqueConstraint(columns={"name", "user_id", "type"})
* },
* indexes={
* @ORM\index(columns={"description"}),
* @ORM\index(columns={"type"})
* }
* )
* @ORM\InheritanceType("SINGLE_TABLE")
* @ORM\DiscriminatorColumn(name="type", type="string")
* @ORM\DiscriminatorMap({"tag" = "Tag", "keyword" = "Keyword"})
* @UniqueEntity(fields={"name", "user"})
*/
abstract class Meta
{
protected $name;
protected $user;
}
儿童班:
/**
* @ORM\Entity
*/
class Tag extends Meta { }
/**
* @ORM\Entity
*/
class Keyword extends Meta { }
答案 1 :(得分:0)
这是一个古老的悬而未决的问题,但是人们仍然可能会遇到这个问题。这可能会帮助您节省时间。
问题在于,默认情况下,UniqueEntityValidator仅采用当前(正在检查的实体)资源库。换句话说,如果您提交合作伙伴,它将仅检查合作伙伴条目。在您的“ single_table”继承映射中,它没有考虑其他实体,例如买方或用户。
要解决您的问题,您可以使用父类名称将其添加到注释entityClass
属性中
@DoctrineAssert\UniqueEntity(fields="username", message="Ce nom d'utilisateur est déjà utilisé, veuillez en choisir un autre.", groups={"registration", "account"}, entityClass="Antho\Test\CoreBundle\Entity\User")
这部分 entityClass =“ Antho \ Test \ CoreBundle \ Entity \ User” 实际上可以解决您的问题。
在这种情况下,验证程序将遍历您的所有用户条目(也包括其子条目)。