Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9e7d196443 | ||
|
|
3e9a0c93eb | ||
|
|
1d533d1d28 | ||
|
|
efa42b6039 |
@@ -1,2 +1,2 @@
|
|||||||
parameters:
|
parameters:
|
||||||
app.version: '0.3.6'
|
app.version: '0.3.8'
|
||||||
|
|||||||
@@ -34,11 +34,11 @@ class Client
|
|||||||
#[ORM\Id]
|
#[ORM\Id]
|
||||||
#[ORM\GeneratedValue]
|
#[ORM\GeneratedValue]
|
||||||
#[ORM\Column]
|
#[ORM\Column]
|
||||||
#[Groups(['client:read', 'project:read'])]
|
#[Groups(['client:read', 'project:read', 'user:list'])]
|
||||||
private ?int $id = null;
|
private ?int $id = null;
|
||||||
|
|
||||||
#[ORM\Column(length: 255)]
|
#[ORM\Column(length: 255)]
|
||||||
#[Groups(['client:read', 'client:write', 'project:read'])]
|
#[Groups(['client:read', 'client:write', 'project:read', 'user:list'])]
|
||||||
private ?string $name = null;
|
private ?string $name = null;
|
||||||
|
|
||||||
#[ORM\Column(length: 255, nullable: true)]
|
#[ORM\Column(length: 255, nullable: true)]
|
||||||
|
|||||||
@@ -43,7 +43,7 @@ class Project
|
|||||||
#[ORM\Id]
|
#[ORM\Id]
|
||||||
#[ORM\GeneratedValue]
|
#[ORM\GeneratedValue]
|
||||||
#[ORM\Column]
|
#[ORM\Column]
|
||||||
#[Groups(['project:read', 'time_entry:read', 'task:read', 'me:read'])]
|
#[Groups(['project:read', 'time_entry:read', 'task:read', 'me:read', 'user:list'])]
|
||||||
private ?int $id = null;
|
private ?int $id = null;
|
||||||
|
|
||||||
#[ORM\Column(length: 10, unique: true)]
|
#[ORM\Column(length: 10, unique: true)]
|
||||||
@@ -53,7 +53,7 @@ class Project
|
|||||||
private ?string $code = null;
|
private ?string $code = null;
|
||||||
|
|
||||||
#[ORM\Column(length: 255)]
|
#[ORM\Column(length: 255)]
|
||||||
#[Groups(['project:read', 'project:write', 'time_entry:read', 'task:read', 'me:read'])]
|
#[Groups(['project:read', 'project:write', 'time_entry:read', 'task:read', 'me:read', 'user:list'])]
|
||||||
private ?string $name = null;
|
private ?string $name = null;
|
||||||
|
|
||||||
#[ORM\Column(type: 'text', nullable: true)]
|
#[ORM\Column(type: 'text', nullable: true)]
|
||||||
|
|||||||
@@ -13,20 +13,21 @@ use ApiPlatform\Metadata\GetCollection;
|
|||||||
use ApiPlatform\Metadata\Post;
|
use ApiPlatform\Metadata\Post;
|
||||||
use App\EventListener\TaskDocumentListener;
|
use App\EventListener\TaskDocumentListener;
|
||||||
use App\State\TaskDocumentProcessor;
|
use App\State\TaskDocumentProcessor;
|
||||||
|
use App\State\TaskDocumentProvider;
|
||||||
use DateTimeImmutable;
|
use DateTimeImmutable;
|
||||||
use Doctrine\ORM\Mapping as ORM;
|
use Doctrine\ORM\Mapping as ORM;
|
||||||
use Symfony\Component\Serializer\Attribute\Groups;
|
use Symfony\Component\Serializer\Attribute\Groups;
|
||||||
|
|
||||||
#[ApiResource(
|
#[ApiResource(
|
||||||
operations: [
|
operations: [
|
||||||
new GetCollection(paginationEnabled: false, security: "is_granted('ROLE_USER')"),
|
new GetCollection(paginationEnabled: false, security: "is_granted('ROLE_USER') or is_granted('ROLE_CLIENT')", provider: TaskDocumentProvider::class),
|
||||||
new Get(security: "is_granted('ROLE_USER')"),
|
new Get(security: "is_granted('ROLE_USER') or is_granted('ROLE_CLIENT')", provider: TaskDocumentProvider::class),
|
||||||
new Post(
|
new Post(
|
||||||
security: "is_granted('ROLE_ADMIN') or is_granted('ROLE_CLIENT')",
|
security: "is_granted('ROLE_ADMIN') or is_granted('ROLE_CLIENT')",
|
||||||
processor: TaskDocumentProcessor::class,
|
processor: TaskDocumentProcessor::class,
|
||||||
deserialize: false,
|
deserialize: false,
|
||||||
),
|
),
|
||||||
new Delete(security: "is_granted('ROLE_ADMIN')"),
|
new Delete(security: "is_granted('ROLE_ADMIN') or is_granted('ROLE_CLIENT')"),
|
||||||
],
|
],
|
||||||
normalizationContext: ['groups' => ['task_document:read']],
|
normalizationContext: ['groups' => ['task_document:read']],
|
||||||
denormalizationContext: ['groups' => ['task_document:write']],
|
denormalizationContext: ['groups' => ['task_document:write']],
|
||||||
|
|||||||
81
src/State/TaskDocumentProvider.php
Normal file
81
src/State/TaskDocumentProvider.php
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace App\State;
|
||||||
|
|
||||||
|
use ApiPlatform\Metadata\Operation;
|
||||||
|
use ApiPlatform\State\ProviderInterface;
|
||||||
|
use App\Entity\TaskDocument;
|
||||||
|
use App\Entity\User;
|
||||||
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
|
use Symfony\Bundle\SecurityBundle\Security;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @implements ProviderInterface<TaskDocument>
|
||||||
|
*/
|
||||||
|
final readonly class TaskDocumentProvider implements ProviderInterface
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private EntityManagerInterface $entityManager,
|
||||||
|
private Security $security,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
public function provide(Operation $operation, array $uriVariables = [], array $context = []): array|TaskDocument|null
|
||||||
|
{
|
||||||
|
$user = $this->security->getUser();
|
||||||
|
assert($user instanceof User);
|
||||||
|
|
||||||
|
$repo = $this->entityManager->getRepository(TaskDocument::class);
|
||||||
|
$isClient = $this->security->isGranted('ROLE_CLIENT') && !$this->security->isGranted('ROLE_ADMIN');
|
||||||
|
|
||||||
|
// Single item
|
||||||
|
if (isset($uriVariables['id'])) {
|
||||||
|
$document = $repo->find($uriVariables['id']);
|
||||||
|
if (null === $document) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($isClient) {
|
||||||
|
$ticket = $document->getClientTicket();
|
||||||
|
if (null === $ticket || $ticket->getSubmittedBy() !== $user) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $document;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Collection
|
||||||
|
$qb = $repo->createQueryBuilder('d')
|
||||||
|
->orderBy('d.id', 'DESC')
|
||||||
|
;
|
||||||
|
|
||||||
|
if ($isClient) {
|
||||||
|
$qb->innerJoin('d.clientTicket', 'ct')
|
||||||
|
->andWhere('ct.submittedBy = :user')
|
||||||
|
->setParameter('user', $user)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply filters from query parameters
|
||||||
|
$filters = $context['filters'] ?? [];
|
||||||
|
if (isset($filters['task'])) {
|
||||||
|
$qb->andWhere('d.task = :task')
|
||||||
|
->setParameter('task', self::extractId($filters['task']))
|
||||||
|
;
|
||||||
|
}
|
||||||
|
if (isset($filters['clientTicket'])) {
|
||||||
|
$qb->andWhere('d.clientTicket = :clientTicket')
|
||||||
|
->setParameter('clientTicket', self::extractId($filters['clientTicket']))
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $qb->getQuery()->getResult();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function extractId(string $value): int
|
||||||
|
{
|
||||||
|
return is_numeric($value) ? (int) $value : (int) basename($value);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user