仅显示在FormFields奏鸣曲中具有特定角色的用户

时间:2014-01-19 21:28:14

标签: symfony doctrine-orm sonata-admin

这里我正在研究一个项目,我使用symfony fosUser和sonata,我有一个Book实体,我用sonata管理。

问题在于我想给一个用户一本书,但是当我想在我的字段中找到用户的角色ROLE_MyRole,我在论坛上搜索几个小时而没有找到时,它变得很复杂。

我很抱歉我最近学习symfony并且还没有足够的经验。

这是我的BookAdmin


class BookAdmin extends Admin
{
    // Fields to be shown on create/edit forms
    protected function configureFormFields(FormMapper $formMapper)
    {
        static $options = array();
        $currentBook = $this->getSubject();
        if (null !== $currentBook->getFileName())
            $options = array(
                'required' => false,
                'help' => 'getWebPath().'">Download File : '.$currentBook->getFileName().'',
            );

        $formMapper
            ->add('title', null, array('label' => 'Titre : '))
            ->add('summary', null, array('label' => 'Résumé : '))
            ->add('category', null, array('label' => 'Catégorie : '))
            ->add('readers', null, array('label' => 'Lecteur(s) : '))
            ->add('file', 'file', $options)
            ;
    }

这是我的读书领域的Book实体

class Book
{
    /**
     * @var integer
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @var string
     *
     * @ORM\Column(name="title", type="string", length=255)
     */
    protected $title;

    /**
     * @var string
     *
     * @ORM\Column(name="summary", type="text")
     */
    protected $summary;

    /**
     * @Assert\File(
     *      mimeTypes={"application/pdf", "application/x-pdf"},
     *      mimeTypesMessage="Only PDF"
     * )
     */
    protected $file;

    /**
     * @var string
     *
     * @ORM\Column(name="file_path", type="string", length=255)
     */
    protected $fileName;

    /**
     * @var \DateTime
     *
     * @Gedmo\Timestampable(on="create")
     * @ORM\Column(name="created_at", type="datetime")
     */
    protected $createdAt;

    /**
     * @var \DateTime
     *
     * @Gedmo\Timestampable(on="update")
     * @ORM\Column(name="updated_at", type="datetime")
     */
    protected $updatedAt;

    /**
     * @var bool
     *
     * @ORM\Column(name="enabled", type="boolean", nullable=true)
     */
    protected $enabled;

    /**
     * @var bool
     *
     * @ORM\Column(name="received_by_reader", type="boolean", nullable=true)
     */
    protected $receivedByReader;

    /**
     * @var bool
     *
     * @ORM\Column(name="download_by_reader", type="boolean", nullable=true)
     */
    protected $downloadByReader;

    /**
     * @var bool
     *
     * @ORM\Column(name="send_by_reader", type="boolean", nullable=true)
     */
    protected $sendByReader;

    /**
     * @var bool
     *
     * @ORM\Column(name="reader_validation", type="boolean", nullable=true)
     */
    protected $readerValidation;

    /**
     * @var bool
     *
     * @ORM\Column(name="edited", type="boolean", nullable=true)
     */
    protected $edited;

    /**
     * @var User
     *
     * @ORM\ManyToOne(targetEntity="Application\Sonata\UserBundle\Entity\User")
     */
    protected $author;

    /**
     * @var ArrayCollection
     *
     * @ORM\ManyToMany(targetEntity="Application\Sonata\UserBundle\Entity\User", cascade={"persist"})
     */
    protected $readers;

谢谢你

2 个答案:

答案 0 :(得分:0)

您可以在管理类中执行以下操作:

$formMapper
    ->add('readers', null, array(
        'label' => 'Lecteur(s) : ',
        'code'  => 'getReadersWithMyRole'
))

并在您的用户实体中定义以下方法:

/**
 * Returns readers with "ROLE_MyRole" role
 *
 * @return array
 */
public function getReadersWithMyRole()
{
    $result = array();

    foreach ($this->getReaders() as $reader) {
        if ($reader->hasRole('ROLE_MyRole')) {
            $result[] = $reader;
        }
    }

    return $result;
}

希望它有所帮助。

答案 1 :(得分:0)

它也不起作用,但我们找到了解决方案,我们可以这样做:

->add('reader', null, array(
'class' => 'ApplicationSonataUserBundle:User',
'label' => 'Lecteur : ',
'query_builder' => function (EntityRepository $er) {
    $qb = $er->createQueryBuilder('u');
    $qb->where($qb->expr()->like('u.roles', $qb->expr()->literal('%ROLE_READER%')));
    return $qb;
}))

如果可以帮助某人