refs #1081. API ImageRepository. Edit Image API with this
testing/ogcore-api/pipeline/head There was a failure building this commit
Details
testing/ogcore-api/pipeline/head There was a failure building this commit
Details
parent
5dc8ffae8c
commit
edee27994b
|
@ -1,31 +1,29 @@
|
|||
resources:
|
||||
App\Entity\Repository:
|
||||
processor: App\State\Processor\RepositoryProcessor
|
||||
input: App\Dto\Input\RepositoryInput
|
||||
output: App\Dto\Output\RepositoryOutput
|
||||
orderBy:
|
||||
RepositoryNumber: 'ASC'
|
||||
App\Entity\ImageRepository:
|
||||
processor: App\State\Processor\ImageRepositoryProcessor
|
||||
input: App\Dto\Input\ImageRepositoryInput
|
||||
output: App\Dto\Output\ImageRepositoryOutput
|
||||
normalizationContext:
|
||||
groups: ['default', 'repository:read']
|
||||
denormalizationContext:
|
||||
groups: ['repository:write']
|
||||
operations:
|
||||
ApiPlatform\Metadata\GetCollection:
|
||||
provider: App\State\Provider\RepositoryProvider
|
||||
provider: App\State\Provider\ImageRepositoryProvider
|
||||
filters:
|
||||
- 'api_platform.filter.repository.order'
|
||||
- 'api_platform.filter.repository.search'
|
||||
ApiPlatform\Metadata\Get:
|
||||
provider: App\State\Provider\RepositoryProvider
|
||||
provider: App\State\Provider\ImageRepositoryProvider
|
||||
ApiPlatform\Metadata\Put:
|
||||
provider: App\State\Provider\RepositoryProvider
|
||||
provider: App\State\Provider\ImageRepositoryProvider
|
||||
ApiPlatform\Metadata\Patch:
|
||||
provider: App\State\Provider\RepositoryProvider
|
||||
provider: App\State\Provider\ImageRepositoryProvider
|
||||
ApiPlatform\Metadata\Post: ~
|
||||
ApiPlatform\Metadata\Delete: ~
|
||||
|
||||
properties:
|
||||
App\Entity\Repository:
|
||||
App\Entity\ImageRepository:
|
||||
id:
|
||||
identifier: false
|
||||
uuid:
|
||||
|
|
|
@ -3,6 +3,8 @@ resources:
|
|||
processor: App\State\Processor\PartitionProcessor
|
||||
input: App\Dto\Input\PartitionInput
|
||||
output: App\Dto\Output\PartitionOutput
|
||||
orderBy:
|
||||
partitionNumber: 'ASC'
|
||||
normalizationContext:
|
||||
groups: ['default', 'partition:read']
|
||||
denormalizationContext:
|
||||
|
|
|
@ -17,7 +17,7 @@ resources:
|
|||
ApiPlatform\Metadata\Get:
|
||||
provider: App\State\Provider\SoftwareProfileProvider
|
||||
normalizationContext:
|
||||
groups: ['software-profile:item:get', 'software-profile:read:collection:short']
|
||||
groups: ['software-profile:read', 'software-profile:item:get', 'software-profile:read:collection:short']
|
||||
ApiPlatform\Metadata\Put:
|
||||
provider: App\State\Provider\SoftwareProfileProvider
|
||||
ApiPlatform\Metadata\Patch:
|
||||
|
|
|
@ -152,3 +152,8 @@ services:
|
|||
bind:
|
||||
$collectionProvider: '@api_platform.doctrine.orm.state.collection_provider'
|
||||
$itemProvider: '@api_platform.doctrine.orm.state.item_provider'
|
||||
|
||||
App\State\Provider\ImageRepositoryProvider:
|
||||
bind:
|
||||
$collectionProvider: '@api_platform.doctrine.orm.state.collection_provider'
|
||||
$itemProvider: '@api_platform.doctrine.orm.state.item_provider'
|
||||
|
|
|
@ -4,6 +4,7 @@ namespace App\Dto\Input;
|
|||
|
||||
use ApiPlatform\Metadata\ApiProperty;
|
||||
use App\Dto\Output\ClientOutput;
|
||||
use App\Dto\Output\ImageRepositoryOutput;
|
||||
use App\Dto\Output\OrganizationalUnitOutput;
|
||||
use App\Dto\Output\SoftwareProfileOutput;
|
||||
use App\Entity\Image;
|
||||
|
@ -50,6 +51,10 @@ final class ImageInput
|
|||
#[ApiProperty(description: 'The software profile of the image')]
|
||||
public ?SoftwareProfileOutput $softwareProfile = null;
|
||||
|
||||
#[Groups(['image:write'])]
|
||||
#[ApiProperty(description: 'The image repository of the image')]
|
||||
public ?ImageRepositoryOutput $imageRepository = null;
|
||||
|
||||
#[Groups(['image:write'])]
|
||||
public ?bool $remotePc = false;
|
||||
|
||||
|
@ -72,6 +77,10 @@ final class ImageInput
|
|||
if ($image->getSoftwareProfile()) {
|
||||
$this->softwareProfile = new SoftwareProfileOutput($image->getSoftwareProfile());
|
||||
}
|
||||
|
||||
if ($image->getRepository()) {
|
||||
$this->imageRepository = new ImageRepositoryOutput($image->getRepository());
|
||||
}
|
||||
}
|
||||
|
||||
public function createOrUpdateEntity(?Image $image = null): Image
|
||||
|
@ -89,6 +98,7 @@ final class ImageInput
|
|||
$image->setInfo($this->info);
|
||||
$image->setSize($this->size);
|
||||
$image->setSoftwareProfile($this->softwareProfile->getEntity());
|
||||
$image->setRepository($this->imageRepository->getEntity());
|
||||
$image->setRemotePc($this->remotePc);
|
||||
|
||||
return $image;
|
||||
|
|
|
@ -8,81 +8,49 @@ use App\Dto\Output\ImageOutput;
|
|||
use App\Dto\Output\OperativeSystemOutput;
|
||||
use App\Dto\Output\OrganizationalUnitOutput;
|
||||
use App\Entity\HardwareProfile;
|
||||
use App\Entity\ImageRepository;
|
||||
use App\Entity\Menu;
|
||||
use App\Entity\Partition;
|
||||
use Symfony\Component\Serializer\Annotation\Groups;
|
||||
use Symfony\Component\Validator\Constraints as Assert;
|
||||
|
||||
final class RepositoryInput
|
||||
final class ImageRepositoryInput
|
||||
{
|
||||
#[Groups(['partition:write'])]
|
||||
#[ApiProperty(description: 'The disk number of the partition', example: 1)]
|
||||
public ?int $diskNumber = null;
|
||||
#[Groups(['repository:write'])]
|
||||
#[ApiProperty(description: 'The name of the repository', example: "Repository 1")]
|
||||
public ?string $name = null;
|
||||
|
||||
#[Groups(['partition:write'])]
|
||||
#[ApiProperty(description: 'The number of the partition', example: 1)]
|
||||
public ?int $partitionNumber = null;
|
||||
|
||||
#[Groups(['partition:write'])]
|
||||
#[ApiProperty(description: 'The code of the partition', example: "code")]
|
||||
public ?string $partitionCode = null;
|
||||
|
||||
#[Assert\NotNull()]
|
||||
#[Groups(['partition:write'])]
|
||||
#[ApiProperty(description: 'The size of the partition', example: 100)]
|
||||
public ?int $size = null;
|
||||
#[Groups(['repository:write'])]
|
||||
#[ApiProperty(description: 'The IP of the repository', example: "")]
|
||||
public ?string $ip = null;
|
||||
|
||||
|
||||
public function __construct(?Repository $partition = null)
|
||||
#[Groups(['repository:write'])]
|
||||
#[ApiProperty(description: 'The comments of the repository', example: "Repository 1 comments")]
|
||||
public ?string $comments = null;
|
||||
|
||||
|
||||
public function __construct(?ImageRepository $repository = null)
|
||||
{
|
||||
if (!$partition) {
|
||||
if (!$repository) {
|
||||
return;
|
||||
}
|
||||
|
||||
$this->diskNumber = $partition->getDiskNumber();
|
||||
$this->partitionNumber = $partition->getPartitionNumber();
|
||||
$this->partitionCode = $partition->getPartitionCode();
|
||||
$this->size = $partition->getSize();
|
||||
$this->cacheContent = $partition->getCacheContent();
|
||||
$this->filesystem = $partition->getFilesystem();
|
||||
|
||||
if ($partition->getOperativeSystem()) {
|
||||
$this->operativeSystem = new OperativeSystemOutput($partition->getOperativeSystem());
|
||||
$this->name = $repository->getName();
|
||||
$this->ip = $repository->getIp();
|
||||
$this->comments = $repository->getComments();
|
||||
}
|
||||
|
||||
if ($partition->getClient()) {
|
||||
$this->client = new ClientOutput($partition->getClient());
|
||||
}
|
||||
$this->memoryUsage = $partition->getMemoryUsage();
|
||||
|
||||
if ($partition->getImage()) {
|
||||
$this->image = new ImageOutput($partition->getImage());
|
||||
}
|
||||
}
|
||||
|
||||
public function createOrUpdateEntity(?Partition $partition = null): Partition
|
||||
public function createOrUpdateEntity(?ImageRepository $repository = null): ImageRepository
|
||||
{
|
||||
if (!$partition) {
|
||||
$partition = new Partition();
|
||||
if (!$repository) {
|
||||
$repository = new ImageRepository();
|
||||
}
|
||||
|
||||
$partition->setDiskNumber($this->diskNumber);
|
||||
$partition->setPartitionNumber($this->partitionNumber);
|
||||
$partition->setPartitionCode($this->partitionCode);
|
||||
$partition->setSize($this->size * 1024);
|
||||
$partition->setCacheContent($this->cacheContent);
|
||||
$partition->setFilesystem($this->filesystem);
|
||||
$repository->setName($this->name);
|
||||
$repository->setIp($this->ip);
|
||||
$repository->setComments($this->comments);
|
||||
|
||||
if ($this->operativeSystem) {
|
||||
$partition->setOperativeSystem($this->operativeSystem->getEntity());
|
||||
}
|
||||
$partition->setClient($this->client->getEntity());
|
||||
$partition->setMemoryUsage($this->memoryUsage * 100);
|
||||
|
||||
if ($this->image) {
|
||||
$partition->setImage($this->image->getEntity());
|
||||
}
|
||||
|
||||
return $partition;
|
||||
return $repository;
|
||||
}
|
||||
}
|
|
@ -101,10 +101,7 @@ final class PartitionInput
|
|||
$partition->setOperativeSystem($this->operativeSystem->getEntity());
|
||||
}
|
||||
$partition->setClient($this->client->getEntity());
|
||||
|
||||
if ($this->memoryUsage) {
|
||||
$partition->setMemoryUsage($this->memoryUsage * 100);
|
||||
}
|
||||
|
||||
if ($this->image) {
|
||||
$partition->setImage($this->image->getEntity());
|
||||
|
|
|
@ -39,6 +39,9 @@ final class ImageOutput extends AbstractOutput
|
|||
#[Groups(['image:read'])]
|
||||
public ?SoftwareProfileOutput $softwareProfile = null;
|
||||
|
||||
#[Groups(['image:read'])]
|
||||
public ?ImageRepositoryOutput $imageRepository = null;
|
||||
|
||||
#[Groups(['image:read'])]
|
||||
public \DateTime $createdAt;
|
||||
|
||||
|
@ -58,6 +61,7 @@ final class ImageOutput extends AbstractOutput
|
|||
$this->info = $image->getInfo();
|
||||
$this->size = $image->getSize();
|
||||
$this->softwareProfile = $image->getSoftwareProfile() ? new SoftwareProfileOutput($image->getSoftwareProfile()) : null;
|
||||
$this->imageRepository = $image->getRepository() ? new ImageRepositoryOutput($image->getRepository()) : null;
|
||||
$this->remotePc = $image->isRemotePc();
|
||||
$this->createdAt = $image->getCreatedAt();
|
||||
$this->createdBy = $image->getCreatedBy();
|
||||
|
|
|
@ -2,7 +2,37 @@
|
|||
|
||||
namespace App\Dto\Output;
|
||||
|
||||
class ImageRepositoryOutput
|
||||
use ApiPlatform\Metadata\Get;
|
||||
use App\Entity\ImageRepository;
|
||||
use Symfony\Component\Serializer\Annotation\Groups;
|
||||
|
||||
#[Get(shortName: 'ImageRepository')]
|
||||
class ImageRepositoryOutput extends AbstractOutput
|
||||
{
|
||||
#[Groups(['repository:read', 'image:read'])]
|
||||
public ?string $name = '';
|
||||
|
||||
#[Groups(['repository:read'])]
|
||||
public ?string $ip = '';
|
||||
|
||||
#[Groups(['repository:read'])]
|
||||
public ?string $comments = '';
|
||||
|
||||
#[Groups(['repository:read'])]
|
||||
public \DateTime $createdAt;
|
||||
|
||||
#[Groups(['repository:read'])]
|
||||
public ?string $createdBy = null;
|
||||
|
||||
public function __construct(ImageRepository $imageRepository)
|
||||
{
|
||||
parent::__construct($imageRepository);
|
||||
|
||||
$this->name = $imageRepository->getName();
|
||||
$this->ip = $imageRepository->getIp();
|
||||
$this->comments = $imageRepository->getComments();
|
||||
$this->createdAt = $imageRepository->getCreatedAt();
|
||||
$this->createdBy = $imageRepository->getCreatedBy();
|
||||
}
|
||||
|
||||
}
|
|
@ -11,7 +11,7 @@ use Symfony\Component\Serializer\Annotation\Groups;
|
|||
#[Get(shortName: 'OrganizationalUnit')]
|
||||
final class OrganizationalUnitOutput extends AbstractOutput
|
||||
{
|
||||
#[Groups(['organizational-unit:read', "client:read", "user:read", 'organizational-unit:read:collection:short'])]
|
||||
#[Groups(['organizational-unit:read', "client:read", "user:read", 'organizational-unit:read:collection:short', 'software-profile:read'])]
|
||||
public string $name;
|
||||
|
||||
#[Groups(['organizational-unit:read'])]
|
||||
|
|
|
@ -2,7 +2,17 @@
|
|||
|
||||
namespace App\Repository;
|
||||
|
||||
class ImageRepository
|
||||
{
|
||||
use App\Entity\Image;
|
||||
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
||||
use Doctrine\Persistence\ManagerRegistry;
|
||||
|
||||
/**
|
||||
* @extends ServiceEntityRepository<Image>
|
||||
*/
|
||||
class ImageRepository extends AbstractRepository
|
||||
{
|
||||
public function __construct(ManagerRegistry $registry)
|
||||
{
|
||||
parent::__construct($registry, Image::class);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,18 @@
|
|||
<?php
|
||||
|
||||
namespace App\Repository;
|
||||
|
||||
use App\Entity\ImageRepository;
|
||||
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
||||
use Doctrine\Persistence\ManagerRegistry;
|
||||
|
||||
/**
|
||||
* @extends ServiceEntityRepository<ImageRepository>
|
||||
*/
|
||||
class ImageRepositoryRepository extends AbstractRepository
|
||||
{
|
||||
public function __construct(ManagerRegistry $registry)
|
||||
{
|
||||
parent::__construct($registry, ImageRepository::class);
|
||||
}
|
||||
}
|
|
@ -2,7 +2,67 @@
|
|||
|
||||
namespace App\State\Processor;
|
||||
|
||||
class ImageRepositoryProcessor
|
||||
{
|
||||
use ApiPlatform\Metadata\Delete;
|
||||
use ApiPlatform\Metadata\Operation;
|
||||
use ApiPlatform\Metadata\Patch;
|
||||
use ApiPlatform\Metadata\Post;
|
||||
use ApiPlatform\Metadata\Put;
|
||||
use ApiPlatform\State\ProcessorInterface;
|
||||
use ApiPlatform\Validator\ValidatorInterface;
|
||||
use App\Dto\Input\ImageRepositoryInput;
|
||||
use App\Dto\Output\ImageRepositoryOutput;
|
||||
use App\Repository\ImageRepositoryRepository;
|
||||
|
||||
readonly class ImageRepositoryProcessor implements ProcessorInterface
|
||||
{
|
||||
public function __construct(
|
||||
private ImageRepositoryRepository $imageRepository,
|
||||
private ValidatorInterface $validator
|
||||
)
|
||||
{
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function process(mixed $data, Operation $operation, array $uriVariables = [], array $context = []): ImageRepositoryOutput|null
|
||||
{
|
||||
switch ($operation){
|
||||
case $operation instanceof Post:
|
||||
case $operation instanceof Put:
|
||||
case $operation instanceof Patch:
|
||||
return $this->processCreateOrUpdate($data, $operation, $uriVariables, $context);
|
||||
case $operation instanceof Delete:
|
||||
return $this->processDelete($data, $operation, $uriVariables, $context);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws \Exception
|
||||
*/
|
||||
private function processCreateOrUpdate($data, Operation $operation, array $uriVariables = [], array $context = []): ImageRepositoryOutput
|
||||
{
|
||||
if (!($data instanceof ImageRepositoryInput)) {
|
||||
throw new \Exception(sprintf('data is not instance of %s', ImageRepositoryInput::class));
|
||||
}
|
||||
|
||||
$entity = null;
|
||||
if (isset($uriVariables['uuid'])) {
|
||||
$entity = $this->imageRepository->findOneByUuid($uriVariables['uuid']);
|
||||
}
|
||||
|
||||
$repository = $data->createOrUpdateEntity($entity);
|
||||
$this->validator->validate($repository);
|
||||
$this->imageRepository->save($repository);
|
||||
|
||||
return new ImageRepositoryOutput($repository);
|
||||
}
|
||||
|
||||
private function processDelete($data, Operation $operation, array $uriVariables = [], array $context = []): null
|
||||
{
|
||||
$user = $this->imageRepository->findOneByUuid($uriVariables['uuid']);
|
||||
$this->imageRepository->delete($user);
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
|
@ -2,7 +2,72 @@
|
|||
|
||||
namespace App\State\Provider;
|
||||
|
||||
class ImageRepositoryProvider
|
||||
{
|
||||
use ApiPlatform\Metadata\Get;
|
||||
use ApiPlatform\Metadata\GetCollection;
|
||||
use ApiPlatform\Metadata\Operation;
|
||||
use ApiPlatform\Metadata\Patch;
|
||||
use ApiPlatform\Metadata\Put;
|
||||
use ApiPlatform\State\Pagination\TraversablePaginator;
|
||||
use ApiPlatform\State\ProviderInterface;
|
||||
use App\Dto\Input\ImageInput;
|
||||
use App\Dto\Input\ImageRepositoryInput;
|
||||
use App\Dto\Output\ImageOutput;
|
||||
use App\Dto\Output\ImageRepositoryOutput;
|
||||
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
||||
|
||||
readonly class ImageRepositoryProvider implements ProviderInterface
|
||||
{
|
||||
public function __construct(
|
||||
private ProviderInterface $collectionProvider,
|
||||
private ProviderInterface $itemProvider
|
||||
)
|
||||
{
|
||||
}
|
||||
|
||||
public function provide(Operation $operation, array $uriVariables = [], array $context = []): object|array|null
|
||||
{
|
||||
switch ($operation){
|
||||
case $operation instanceof GetCollection:
|
||||
return $this->provideCollection($operation, $uriVariables, $context);
|
||||
case $operation instanceof Patch:
|
||||
case $operation instanceof Put:
|
||||
return $this->provideInput($operation, $uriVariables, $context);
|
||||
case $operation instanceof Get:
|
||||
return $this->provideItem($operation, $uriVariables, $context);
|
||||
}
|
||||
}
|
||||
|
||||
private function provideCollection(Operation $operation, array $uriVariables = [], array $context = []): object
|
||||
{
|
||||
$paginator = $this->collectionProvider->provide($operation, $uriVariables, $context);
|
||||
|
||||
$items = new \ArrayObject();
|
||||
foreach ($paginator->getIterator() as $item){
|
||||
$items[] = new ImageRepositoryOutput($item);
|
||||
}
|
||||
|
||||
return new TraversablePaginator($items, $paginator->getCurrentPage(), $paginator->getItemsPerPage(), $paginator->getTotalItems());
|
||||
}
|
||||
|
||||
public function provideItem(Operation $operation, array $uriVariables = [], array $context = []): object|array|null
|
||||
{
|
||||
$item = $this->itemProvider->provide($operation, $uriVariables, $context);
|
||||
|
||||
if (!$item) {
|
||||
throw new NotFoundHttpException('Image not found');
|
||||
}
|
||||
|
||||
return new ImageRepositoryOutput($item);
|
||||
}
|
||||
|
||||
public function provideInput(Operation $operation, array $uriVariables = [], array $context = []): object|array|null
|
||||
{
|
||||
if (isset($uriVariables['uuid'])) {
|
||||
$item = $this->itemProvider->provide($operation, $uriVariables, $context);
|
||||
|
||||
return $item !== null ? new ImageRepositoryInput($item) : null;
|
||||
}
|
||||
|
||||
return new ImageRepositoryInput();
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue