src/Entity/AdminGroup.php line 57
<?php
namespace App\Entity;
use Doctrine\ORM\Mapping as ORM,
Doctrine\DBAL\Types\Types,
Doctrine\Common\Collections\Collection,
Doctrine\Common\Collections\ArrayCollection;
use Symfony\Component\Serializer\Annotation\Groups,
Symfony\Component\Validator\Constraints as Assert;
use ApiPlatform\Metadata\ApiResource,
ApiPlatform\Metadata\ApiProperty,
ApiPlatform\Metadata\Get,
ApiPlatform\Metadata\GetCollection,
ApiPlatform\Metadata\Post,
ApiPlatform\Metadata\Put,
ApiPlatform\Metadata\Delete,
ApiPlatform\Metadata\ApiFilter,
ApiPlatform\Doctrine\Orm\Filter\SearchFilter,
ApiPlatform\Doctrine\Orm\Filter\BooleanFilter,
ApiPlatform\Doctrine\Orm\Filter\OrderFilter;
use App\Entity\Trait\IdTrait,
App\Entity\Trait\UuidTrait,
App\Entity\Trait\OrdStatTrait,
App\Entity\Trait\TimestampableTrait,
App\Entity\Interface\SimpleEntityInterface,
App\Entity\Interface\OrdStatableInterface,
App\Repository\AdminGroupRepository;
use App\StateProvider\AdminGroupCollectionProvider,
App\Validator\Constraints\AdminGroup as CustomAssert;
use App\Lib\Actions;
use App\Lib\ModuleRoles;
#[ApiResource(
description: 'Administration groups',
normalizationContext: ['groups' => ['read', 'read:' . self::class]],
denormalizationContext: ['groups' => ['write']],
security: 'is_granted("' . Admin::class . '")',
order: ['ord' => 'desc'],
operations: [
new GetCollection(provider: AdminGroupCollectionProvider::class),
new Post(),
new Get(securityPostDenormalize: 'is_granted("' . Actions::VIEW . '", object)',),
new Put(securityPostDenormalize: 'is_granted("' . Actions::EDIT . '", object)',),
new Delete(securityPostDenormalize: 'is_granted("' . Actions::DELETE . '", object)',),
],
extraProperties: ['standard_put' => false],
)]
#[ApiFilter(SearchFilter::class, properties: ['title' => 'partial'])]
#[ApiFilter(BooleanFilter::class, properties: ['isSuperAdmin', 'stat'])]
#[ApiFilter(OrderFilter::class, properties: ['title', 'isSuperAdmin', 'ord', 'stat', 'createdAt', 'updatedAt'])]
#[ORM\Entity(repositoryClass: AdminGroupRepository::class)]
class AdminGroup implements SimpleEntityInterface, OrdStatableInterface
{
use IdTrait,
UuidTrait,
OrdStatTrait,
TimestampableTrait;
#[ApiProperty(description: 'Title')]
#[Groups(['read', 'write'])]
#[Assert\NotBlank]
#[ORM\Column(type: Types::STRING, length: 191, unique: true)]
private string $title;
#[ApiProperty(description: 'Resources to which this group has access')]
#[Groups(['write'])]
#[CustomAssert\ValidResourceAccess]
#[ORM\Column(type: Types::JSON)]
private array $resourceAccess = [];
#[ApiProperty(description: 'Is super admin')]
#[Groups(['read', 'write'])]
#[ORM\Column(type: Types::BOOLEAN, options: ['default' => false])]
private bool $isSuperAdmin = false;
#[ApiProperty(description: 'Is openform')]
#[Groups(['openform'])]
#[ORM\Column(type: Types::BOOLEAN, options: ['default' => false])]
private bool $isOpenform = false;
#[ApiProperty(description: 'Members of group')]
#[ORM\OneToMany(targetEntity: Admin::class, mappedBy: 'group')]
private Collection $members;
public function __construct(string $title)
{
$this->setUuid();
$this->title = $title;
$this->members = new ArrayCollection();
$this->createdAt = new \DateTimeImmutable();
$this->updatedAt = new \DateTimeImmutable();
}
public function getTitle(): string
{
return $this->title;
}
public function setTitle(string $title): self
{
$this->title = $title;
return $this;
}
public function getFullyQualifiedResourceAccess(): array
{
return $this->resourceAccess;
}
#[Groups(['read'])]
public function getResourceAccess(): array
{
return array_map(
function (string $resourceFqcn) {
switch(true) {
case defined(ModuleRoles::class . '::ROLE_MODULE_' . strtoupper($resourceFqcn)):
return $resourceFqcn;
case class_exists($resourceFqcn):
return lcfirst(short_class_name($resourceFqcn));
default:
throw new \Exception('Resource access is invalid.');
}
},
$this->resourceAccess
);
}
public function setResourceAccess(array $resourceAccess): self
{
$this->resourceAccess = array_map(
function (string $resourceScn) {
switch(true) {
case defined(ModuleRoles::class . '::ROLE_MODULE_' . strtoupper($resourceScn)):
return strtolower($resourceScn);
case class_exists($fqcn = __NAMESPACE__ . '\\' . ucfirst($resourceScn)):
return $fqcn;
default:
throw new \Exception('Resource access is invalid.');
}
},
$resourceAccess
);
return $this;
}
public function getIsSuperAdmin(): bool
{
return $this->isSuperAdmin;
}
public function setIsSuperAdmin(bool $isSuperAdmin): self
{
$this->isSuperAdmin = $isSuperAdmin;
return $this;
}
public function getIsOpenform(): bool
{
return $this->isOpenform;
}
public function setIsOpenform(bool $isOpenform): self
{
$this->isOpenform = $isOpenform;
return $this;
}
public function getMembers(): Collection
{
return $this->members;
}
public function addMember(Admin $member): self
{
if ($this->members->contains($member)) {
return $this;
}
$this->members[] = $member;
$member->setGroup($this);
return $this;
}
public function removeMember(Admin $member): self
{
$this->members->removeElement($member);
$member->setGroup(null);
return $this;
}
}