Notification.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Entity\Core;
  4. use ApiPlatform\Core\Annotation\ApiResource;
  5. use App\Entity\Access\Access;
  6. use App\Entity\Organization\Organization;
  7. use App\Repository\Core\NotificationRepository;
  8. use DH\Auditor\Provider\Doctrine\Auditing\Annotation\Auditable;
  9. use Doctrine\Common\Collections\ArrayCollection;
  10. use Doctrine\Common\Collections\Collection;
  11. use Doctrine\ORM\Mapping as ORM;
  12. use JetBrains\PhpStorm\Pure;
  13. use Symfony\Component\Validator\Constraints as Assert;
  14. use App\Enum\Core\NotificationTypeEnum;
  15. /**
  16. * @todo : A la suite de la migration, il faut supprimer le nom de la table pour avoir une table Notification, et supprimer l'attribut discr.
  17. *
  18. * Classe Notification. qui permet de gérer les notifications aux utilisateurs.
  19. */
  20. #[Auditable]
  21. #[ApiResource(
  22. collectionOperations:[
  23. 'get' => [
  24. 'pagination_client_items_per_page' => true,
  25. 'pagination_maximum_items_per_page' => 20,
  26. 'order' => [
  27. 'id' => 'DESC'
  28. ]
  29. ]
  30. ],
  31. itemOperations: [
  32. 'get'
  33. ]
  34. )]
  35. #[ORM\Entity(repositoryClass:NotificationRepository::class)]
  36. #[ORM\Table(name: 'Information')]
  37. class Notification
  38. {
  39. #[ORM\Id]
  40. #[ORM\Column]
  41. #[ORM\GeneratedValue]
  42. private ?int $id = null;
  43. #[ORM\Column(length: 255, nullable: false)]
  44. private string $discr = 'notification';
  45. #[ORM\ManyToOne(inversedBy: 'notifications')]
  46. #[ORM\JoinColumn(nullable: false)]
  47. private ?Access $recipientAccess;
  48. #[ORM\ManyToOne(inversedBy: 'notifications')]
  49. #[ORM\JoinColumn(nullable: false)]
  50. private ?Organization $recipientOrganization;
  51. #[ORM\Column(length: 40, nullable: true)]
  52. private ?string $name = null;
  53. #[ORM\Column(type: 'datetime', nullable: true)]
  54. private ?\DateTimeInterface $createDate;
  55. #[ORM\Column(type: 'datetime', nullable: true)]
  56. private ?\DateTimeInterface $updateDate;
  57. #[ORM\Column(type: 'json', length: 4294967295, nullable: true)]
  58. private mixed $message = [];
  59. #[ORM\Column(nullable: true)]
  60. #[Assert\Choice(callback: [NotificationTypeEnum::class, 'toArray'], message: 'invalid-type')]
  61. private ?string $type = null;
  62. #[ORM\Column(length: 255, nullable: true)]
  63. private ?string $link = null;
  64. #[ORM\Column(type: 'date', nullable: true)]
  65. private ?\DateTimeInterface $availabilityDate = null;
  66. #[ORM\OneToMany(mappedBy: 'notification', targetEntity: NotificationUser::class, cascade: ['persist'], orphanRemoval: true)]
  67. private Collection $notificationUsers;
  68. #[Pure] public function __construct()
  69. {
  70. $this->notificationUsers = new ArrayCollection();
  71. }
  72. public function getId(): ?int
  73. {
  74. return $this->id;
  75. }
  76. public function setName(?string $name): self
  77. {
  78. $this->name = $name;
  79. return $this;
  80. }
  81. public function getName(): ?string
  82. {
  83. return $this->name;
  84. }
  85. public function setRecipientAccess(?Access $recipientAccess): self
  86. {
  87. $this->recipientAccess = $recipientAccess;
  88. return $this;
  89. }
  90. public function getRecipientAccess(): ?Access
  91. {
  92. return $this->recipientAccess;
  93. }
  94. /**
  95. * @return Organization|null
  96. */
  97. public function getRecipientOrganization(): ?Organization
  98. {
  99. return $this->recipientOrganization;
  100. }
  101. /**
  102. * @param Organization|null $recipientOrganization
  103. * @return Notification
  104. */
  105. public function setRecipientOrganization(?Organization $recipientOrganization): Notification
  106. {
  107. $this->recipientOrganization = $recipientOrganization;
  108. return $this;
  109. }
  110. /**
  111. * @return \DateTimeInterface|null
  112. */
  113. public function getCreateDate(): ?\DateTimeInterface
  114. {
  115. return $this->createDate;
  116. }
  117. /**
  118. * @param \DateTimeInterface|null $createDate
  119. */
  120. public function setCreateDate(?\DateTimeInterface $createDate): self
  121. {
  122. $this->createDate = $createDate;
  123. return $this;
  124. }
  125. /**
  126. * @return \DateTimeInterface|null
  127. */
  128. public function getUpdateDate(): ?\DateTimeInterface
  129. {
  130. return $this->updateDate;
  131. }
  132. /**
  133. * @param \DateTimeInterface|null $updateDate
  134. */
  135. public function setUpdateDate(?\DateTimeInterface $updateDate): self
  136. {
  137. $this->updateDate = $updateDate;
  138. return $this;
  139. }
  140. public function setMessage(mixed $message): self
  141. {
  142. $this->message = $message;
  143. return $this;
  144. }
  145. public function getMessage(): mixed
  146. {
  147. if(!is_array( $this->message)){
  148. return ['about' => $this->message];
  149. }
  150. return $this->message;
  151. }
  152. public function setType(?string $type): self
  153. {
  154. $this->type = $type;
  155. return $this;
  156. }
  157. public function getType(): ?string
  158. {
  159. return $this->type;
  160. }
  161. public function setLink(?string $link): self
  162. {
  163. $this->link = $link;
  164. return $this;
  165. }
  166. public function getLink(): ?string
  167. {
  168. return $this->link;
  169. }
  170. public function getAvailabilityDate(): ?string {
  171. return $this->availabilityDate?->format('Y-m-d');
  172. }
  173. public function setAvailabilityDate(?\DateTime $availabilityDate = null): self {
  174. if($availabilityDate == null) $availabilityDate = new \DateTime();
  175. $this->availabilityDate = $availabilityDate;
  176. return $this;
  177. }
  178. public function getNotificationUsers(): Collection
  179. {
  180. return $this->notificationUsers;
  181. }
  182. public function addNotificationUser(NotificationUser $notificationUsers): self
  183. {
  184. if (!$this->notificationUsers->contains($notificationUsers)) {
  185. $this->notificationUsers[] = $notificationUsers;
  186. $notificationUsers->setNotification($this);
  187. }
  188. return $this;
  189. }
  190. public function removeNotificationUser(NotificationUser $notificationUsers): self
  191. {
  192. if ($this->notificationUsers->removeElement($notificationUsers)) {
  193. // set the owning side to null (unless already changed)
  194. if ($notificationUsers->getNotification() === $this) {
  195. $notificationUsers->setNotification(null);
  196. }
  197. }
  198. return $this;
  199. }
  200. public function getDiscr(): ?string
  201. {
  202. return $this->discr;
  203. }
  204. public function setDiscr(string $discr): self
  205. {
  206. $this->discr = $discr;
  207. return $this;
  208. }
  209. }