News.php 3.18 KB
Newer Older
Julien Jorry committed
1 2 3 4 5 6 7 8 9 10
<?php

namespace App\Entity;

use App\Entity\EntityTrait\EnablableEntityTrait;
use App\Entity\EntityTrait\NameSlugContentEntityTrait;
use Doctrine\ORM\Mapping as ORM;
use Gedmo\Mapping\Annotation as Gedmo;
use Gedmo\Timestampable\Traits\TimestampableEntity;
use Symfony\Component\Validator\Constraints as Assert;
11 12
use ApiPlatform\Core\Annotation\ApiResource;
use Symfony\Component\Serializer\Annotation\Groups;
Julien Jorry committed
13 14

/**
15 16 17 18 19 20 21 22 23 24
 * ApiResource(
 *     attributes={"security"="is_granted('ROLE_ADMIN_NEWS_GERER_VIEW')"},
 *     collectionOperations={
 *         "get"={"security"="is_granted('ROLE_ADMIN_NEWS_GERER_LIST')"},
 *         "post"={"security"="is_granted('ROLE_ADMIN_NEWS_GERER_EDIT')"}
 *     },
 *     itemOperations={
 *         "get"={"security"="is_granted('ROLE_ADMIN_NEWS_GERER_VIEW')"},
 *         "put"={"security"="is_granted('ROLE_ADMIN_NEWS_GERER_EDIT')"},
 *     },
25 26 27
 *     normalizationContext={"groups"={"read"}},
 *     denormalizationContext={"groups"={"write"}}
 * )
28
 * @ORM\Entity(repositoryClass="App\Repository\NewsRepository")
Julien Jorry committed
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
 * @ORM\HasLifecycleCallbacks()
 * @ORM\Table(name="news")
 */
class News
{
    use TimestampableEntity,
        NameSlugContentEntityTrait,
        EnablableEntityTrait;

    /**
     * @var int
     *
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
Julien Jorry committed
48 49 50 51 52
    * @var \Application\Sonata\MediaBundle\Entity\Media
    * @ORM\ManyToOne(targetEntity="App\Application\Sonata\MediaBundle\Entity\Media", cascade={"persist"}, fetch="LAZY")
    * @ORM\JoinColumn(name="media_id", referencedColumnName="id")
    */
    protected $media;
Julien Jorry committed
53 54 55 56 57 58 59 60

    /**
     * @var bool
     *
     * @ORM\Column(type="boolean", name="visible_by_all_groups")
     */
    private $visibleByAllGroups = true;

61 62 63 64 65 66
    /**
     * @ORM\ManyToOne(targetEntity="User", inversedBy="news")
     * @ORM\JoinColumn(name="user_id", referencedColumnName="id", nullable=false)
     */
    private $user;

Julien Jorry committed
67 68 69 70 71 72 73 74 75
    /**
     * @return int
     */
    public function getId(): int
    {
        return $this->id;
    }

    /**
Julien Jorry committed
76 77 78 79
    * Get media
    * @return
    */
    public function getMedia()
Julien Jorry committed
80
    {
Julien Jorry committed
81
        return $this->media;
Julien Jorry committed
82 83 84
    }

    /**
Julien Jorry committed
85 86 87 88
    * Set media
    * @return $this
    */
    public function setMedia($media)
Julien Jorry committed
89
    {
Julien Jorry committed
90 91
        $this->media = $media;
        return $this;
Julien Jorry committed
92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
    }

    /**
     * @return bool
     */
    public function isVisibleByAllGroups(): bool
    {
        return $this->visibleByAllGroups;
    }

    /**
     * @param bool $visibleByAllGroups
     * @return News
     */
    public function setVisibleByAllGroups(bool $visibleByAllGroups)
    {
        $this->visibleByAllGroups = $visibleByAllGroups;
        return $this;
    }
111 112 113 114 115 116 117 118 119 120 121 122 123

    public function __toString(): string
    {
        $return = '';

        if ($this->getName() != null) {
            $return = $this->getName();
        }
        if ($this->getCreatedAt() != null) {
            $return .= ' (crée le '.$this->getCreatedAt()->format('d/m/Y H:i').')';
        }
        return $return;
    }
124 125 126 127 128 129 130 131 132 133 134 135

    public function getUser(): ?User
    {
        return $this->user;
    }

    public function setUser(?User $user): self
    {
        $this->user = $user;

        return $this;
    }
Julien Jorry committed
136
}