<?php
namespace App\Entity;
use ApiPlatform\Core\Annotation\ApiFilter;
use ApiPlatform\Core\Annotation\ApiResource;
use ApiPlatform\Core\Bridge\Doctrine\Orm\Filter\OrderFilter;
use ApiPlatform\Core\Bridge\Doctrine\Orm\Filter\SearchFilter;
use ApiPlatform\Core\Serializer\Filter\PropertyFilter;
use Doctrine\ORM\Mapping as ORM;
use Gedmo\Timestampable\Traits\TimestampableEntity;
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;
use Symfony\Component\Serializer\Annotation\Groups;
/**
* @ORM\Entity(repositoryClass="App\Repository\AdminRepository")
* @ORM\HasLifecycleCallbacks()
* @UniqueEntity(fields={"user","company"},errorPath="user",message="This user is already in use on that company.")
*/
#[ApiResource(
attributes: ['security' => "is_granted('ROLE_USER')"],
normalizationContext: ['groups' => ['admin:read']],
denormalizationContext: ['groups' => ['admin:write']],
collectionOperations: ['get', 'post' => ['security' => "is_granted('ROLE_ADMIN')"]],
itemOperations: ['get', 'put' => ['security' => "is_granted('ROLE_ADMIN') or object.owner == user"], 'delete'],
)]
#[ApiFilter(SearchFilter::class, properties: ['user' => 'exact', 'company' => 'exact'])]
#[ApiFilter(PropertyFilter::class)]
#[ApiFilter(OrderFilter::class, properties: ['id', 'user.email', 'company.name', 'createdAt'], arguments: ['orderParameterName' => 'order'])]
class Admin
{
use TimestampableEntity;
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\ManyToOne(targetEntity="App\Entity\User")
* @ORM\JoinColumn(nullable=false, name="user_id", referencedColumnName="id", onDelete="CASCADE")
* @Groups({"admin:read", "admin:write"})
*/
private $user;
/**
* @ORM\ManyToOne(targetEntity="App\Entity\Company", inversedBy="admins")
* @ORM\JoinColumn(nullable=false, name="company_id", referencedColumnName="id", onDelete="CASCADE")
* @Groups({"admin:read", "admin:write"})
*/
private $company;
/**
* @return string
*/
public function __toString()
{
return $this->getUser()->getFirstName() . ' ' . $this->getUser()->getLastName() . ' (' . $this->getUser()->getEmail() . ')';
}
public function getId(): ?int
{
return $this->id;
}
public function getUser(): ?User
{
return $this->user;
}
public function setUser(?User $user): self
{
$this->user = $user;
return $this;
}
public function getCompany(): ?Company
{
return $this->company;
}
public function setCompany(?Company $company): self
{
$this->company = $company;
return $this;
}
/**
* @Groups({"admin:read"})
* Returns createdAt.
*/
public function getCreatedAt(): ?\DateTimeInterface
{
return $this->createdAt;
}
}