component

This commit is contained in:
xantxo coquillard 2022-04-09 12:55:56 +02:00
parent fbc49281d1
commit f7e226eb44
30 changed files with 757 additions and 9 deletions

View File

@ -20,7 +20,7 @@ services:
- '../src/Entity/' - '../src/Entity/'
- '../src/Kernel.php' - '../src/Kernel.php'
App\Controller\: App\Controller\:
resource: '../src/App/Controller' resource: '../src/Controller'
tags: ['controller.service_arguments'] tags: ['controller.service_arguments']
# add more service definitions when explicit configuration is needed # add more service definitions when explicit configuration is needed

View File

@ -0,0 +1,29 @@
<?php
namespace App\Component\Customer\Infrastructure;
use App\Component\Customer\Domain\Customer;
use App\Component\Customer\Domain\CustomerDataMapper;
use App\Component\Customer\Domain\CustomerRepository;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
class CustomerDatabaseAdapter extends ServiceEntityRepository implements CustomerDataMapper, CustomerRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Customer::class);
}
public function findById(int $id): Customer
{
// TODO: Implement findById() method.
}
public function findAll(): array
{
// TODO: Implement findAll() method.
}
}

View File

@ -0,0 +1,18 @@
<?php
namespace App\Component\File\Domain;
#[ORM\Entity, ORM\Table(name:"files")]
class File
{
#[ORM\Id, ORM\GeneratedValue(strategy: 'AUTO')]
#[ORM\Column(type:Types::INTEGER)]
private int $id;
#[ORM\Column]
public \DateTime $created;
#[ORM\Column]
public \DateTime $updated;
}

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\File\Domain;
interface FileDataMapper
{
}

View File

@ -0,0 +1,9 @@
<?php
namespace App\Component\File\Domain;
interface FileRepository
{
public function findById(int $id): File;
public function findAll(): array;
}

View File

@ -0,0 +1,29 @@
<?php
namespace App\Component\File\Infrastructure;
use App\Component\File\Domain\File;
use App\Component\File\Domain\FileDataMapper;
use App\Component\File\Domain\FileRepository;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
class FileDatabaseAdapter extends ServiceEntityRepository implements FileDataMapper, FileRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, File::class);
}
public function findById(int $id): File
{
// TODO: Implement findById() method.
}
public function findAll(): array
{
// TODO: Implement findAll() method.
}
}

View File

@ -0,0 +1,91 @@
<?php
namespace App\Component\Material\Domain;
use Doctrine\DBAL\Types\Types;
#[ORM\Entity, ORM\Table(name:"materials")]
class Material
{
#[ORM\Id, ORM\GeneratedValue(strategy: 'AUTO')]
#[ORM\Column(type:Types::INTEGER)]
private int $id;
#[ORM\Column(type:Types::STRING, length:255)]
private string $label;
#[ORM\Column]
public \DateTime $created;
#[ORM\Column]
public \DateTime $updated;
public function __construct()
{
}
/**
* @return int
*/
public function getId(): int
{
return $this->id;
}
/**
* @param int $id
*/
public function setId(int $id): void
{
$this->id = $id;
}
/**
* @return string
*/
public function getLabel(): string
{
return $this->label;
}
/**
* @param string $label
*/
public function setLabel(string $label): void
{
$this->label = $label;
}
/**
* @return \DateTime
*/
public function getCreated(): \DateTime
{
return $this->created;
}
/**
* @param \DateTime $created
*/
public function setCreated(\DateTime $created): void
{
$this->created = $created;
}
/**
* @return \DateTime
*/
public function getUpdated(): \DateTime
{
return $this->updated;
}
/**
* @param \DateTime $updated
*/
public function setUpdated(\DateTime $updated): void
{
$this->updated = $updated;
}
}

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\Material\Domain;
interface MaterialDataMapper
{
}

View File

@ -0,0 +1,9 @@
<?php
namespace App\Component\Material\Domain;
interface MaterialRepository
{
public function findById(int $id): Material;
public function findAll(): array;
}

View File

@ -0,0 +1,29 @@
<?php
namespace App\Component\Material\Infrastructure;
use App\Component\Material\Domain\Material;
use App\Component\Material\Domain\MaterialDataMapper;
use App\Component\Material\Domain\MaterialRepository;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
class MaterialDatabaseAdapter extends ServiceEntityRepository implements MaterialDataMapper, MaterialRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Material::class);
}
public function findById(int $id): Material
{
// TODO: Implement findById() method.
}
public function findAll(): array
{
// TODO: Implement findAll() method.
}
}

View File

@ -0,0 +1,255 @@
<?php
namespace App\Component\Order\Domain;
use App\Component\Customer\Domain\Customer;
use App\Component\File\Domain\File;
use App\Component\Printer\Domain\Printer;
use App\Component\Spool\Domain\Spool;
#[ORM\Entity, ORM\Table(name:"orders")]
class Order
{
#[ORM\Id, ORM\GeneratedValue(strategy: 'AUTO')]
#[ORM\Column(type:Types::INTEGER)]
private int $id;
private Printer $printer;
private Customer $customer;
private Spool $spool;
private float $printWeights;
private int $printMinutes;
private int $printHours;
private int $userHourlyCost;
private float $sellPrice;
private File $file;
private int $status;
#[ORM\Column]
public \DateTime $created;
#[ORM\Column]
public \DateTime $updated;
public function __construct()
{
}
/**
* @return int
*/
public function getId(): int
{
return $this->id;
}
/**
* @param int $id
*/
public function setId(int $id): void
{
$this->id = $id;
}
/**
* @return Printer
*/
public function getPrinter(): Printer
{
return $this->printer;
}
/**
* @param Printer $printer
*/
public function setPrinter(Printer $printer): void
{
$this->printer = $printer;
}
/**
* @return Customer
*/
public function getCustomer(): Customer
{
return $this->customer;
}
/**
* @param Customer $customer
*/
public function setCustomer(Customer $customer): void
{
$this->customer = $customer;
}
/**
* @return Spool
*/
public function getSpool(): Spool
{
return $this->spool;
}
/**
* @param Spool $spool
*/
public function setSpool(Spool $spool): void
{
$this->spool = $spool;
}
/**
* @return float
*/
public function getPrintWeights(): float
{
return $this->printWeights;
}
/**
* @param float $printWeights
*/
public function setPrintWeights(float $printWeights): void
{
$this->printWeights = $printWeights;
}
/**
* @return int
*/
public function getPrintMinutes(): int
{
return $this->printMinutes;
}
/**
* @param int $printMinutes
*/
public function setPrintMinutes(int $printMinutes): void
{
$this->printMinutes = $printMinutes;
}
/**
* @return int
*/
public function getPrintHours(): int
{
return $this->printHours;
}
/**
* @param int $printHours
*/
public function setPrintHours(int $printHours): void
{
$this->printHours = $printHours;
}
/**
* @return int
*/
public function getUserHourlyCost(): int
{
return $this->userHourlyCost;
}
/**
* @param int $userHourlyCost
*/
public function setUserHourlyCost(int $userHourlyCost): void
{
$this->userHourlyCost = $userHourlyCost;
}
/**
* @return float
*/
public function getSellPrice(): float
{
return $this->sellPrice;
}
/**
* @param float $sellPrice
*/
public function setSellPrice(float $sellPrice): void
{
$this->sellPrice = $sellPrice;
}
/**
* @return File
*/
public function getFile(): File
{
return $this->file;
}
/**
* @param File $file
*/
public function setFile(File $file): void
{
$this->file = $file;
}
/**
* @return int
*/
public function getStatus(): int
{
return $this->status;
}
/**
* @param int $status
*/
public function setStatus(int $status): void
{
$this->status = $status;
}
/**
* @return \DateTime
*/
public function getCreated(): \DateTime
{
return $this->created;
}
/**
* @param \DateTime $created
*/
public function setCreated(\DateTime $created): void
{
$this->created = $created;
}
/**
* @return \DateTime
*/
public function getUpdated(): \DateTime
{
return $this->updated;
}
/**
* @param \DateTime $updated
*/
public function setUpdated(\DateTime $updated): void
{
$this->updated = $updated;
}
}

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\Order\Domain;
interface OrderDataMapper
{
}

View File

@ -0,0 +1,9 @@
<?php
namespace App\Component\Order\Domain;
interface OrderRepository
{
public function findById(int $id): Order;
public function findAll(): array;
}

View File

@ -0,0 +1,29 @@
<?php
namespace App\Component\Order\Infrastructure;
use App\Component\Order\Domain\Order;
use App\Component\Order\Domain\OrderDataMapper;
use App\Component\Order\Domain\OrderRepository;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
class OrderDatabaseAdapter extends ServiceEntityRepository implements OrderDataMapper, OrderRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Order::class);
}
public function findById(int $id): Order
{
// TODO: Implement findById() method.
}
public function findAll(): array
{
// TODO: Implement findAll() method.
}
}

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\Printer\Domain;
class Printer
{
}

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\Printer\Domain;
interface PrinterDataMapper
{
}

View File

@ -0,0 +1,9 @@
<?php
namespace App\Component\Printer\Domain;
interface PrinterRepository
{
public function findById(int $id): Printer;
public function findAll(): array;
}

View File

@ -0,0 +1,29 @@
<?php
namespace App\Component\Printer\Infrastructure;
use App\Component\Printer\Domain\Printer;
use App\Component\Printer\Domain\PrinterDataMapper;
use App\Component\Printer\Domain\PrinterRepository;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
class PrinterDatabaseAdapter extends ServiceEntityRepository implements PrinterDataMapper, PrinterRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Printer::class);
}
public function findById(int $id): Printer
{
// TODO: Implement findById() method.
}
public function findAll(): array
{
// TODO: Implement findAll() method.
}
}

View File

@ -2,8 +2,12 @@
namespace App\Component\Role\Domain; namespace App\Component\Role\Domain;
use App\Component\User\Domain\User;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;
use Doctrine\DBAL\Types\Types; use Doctrine\DBAL\Types\Types;
use Doctrine\ORM\Mapping as ORM; use Doctrine\ORM\Mapping as ORM;
use JetBrains\PhpStorm\Pure;
#[ORM\Entity, ORM\Table(name:"roles")] #[ORM\Entity, ORM\Table(name:"roles")]
@ -17,14 +21,19 @@ class Role
#[ORM\Column(type:Types::STRING, length:255)] #[ORM\Column(type:Types::STRING, length:255)]
private string $name; private string $name;
#[ORM\OneToMany(mappedBy:"role", targetEntity: User::class)]
private Collection $users;
#[ORM\Column] #[ORM\Column]
public \DateTime $created; public \DateTime $created;
#[ORM\Column] #[ORM\Column]
public \DateTime $updated; public \DateTime $updated;
#[Pure]
public function __construct() public function __construct()
{ {
$this->users = new ArrayCollection();
} }
/** /**
@ -59,4 +68,52 @@ class Role
$this->name = $name; $this->name = $name;
} }
/**
* @return Collection
*/
public function getUsers(): Collection
{
return $this->users;
}
/**
* @param Collection $user
*/
public function setUsers(Collection $users): void
{
$this->users = $users;
}
/**
* @return \DateTime
*/
public function getCreated(): \DateTime
{
return $this->created;
}
/**
* @param \DateTime $created
*/
public function setCreated(\DateTime $created): void
{
$this->created = $created;
}
/**
* @return \DateTime
*/
public function getUpdated(): \DateTime
{
return $this->updated;
}
/**
* @param \DateTime $updated
*/
public function setUpdated(\DateTime $updated): void
{
$this->updated = $updated;
}
} }

View File

@ -19,16 +19,16 @@ class RoleDatabaseAdapter extends ServiceEntityRepository implements RoleDataMap
public function findById(int $id): Role public function findById(int $id): Role
{ {
$user = $this->find($id); $role = $this->find($id);
if (!$user) if (!$role)
{ {
throw new Exception( throw new Exception(
'L\'utilisateur n\'existe pas' 'Le role n\'existe pas'
); );
} }
return $user; return $role;
} }
public function findAll(): array public function findAll(): array

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\Spool\Domain;
class Spool
{
}

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\Spool\Domain;
interface SpoolDataMapper
{
}

View File

@ -0,0 +1,9 @@
<?php
namespace App\Component\Spool\Domain;
interface SpoolRepository
{
public function findById(int $id): Spool;
public function findAll(): array;
}

View File

@ -0,0 +1,29 @@
<?php
namespace App\Component\Spool\Infrastructure;
use App\Component\Spool\Domain\Spool;
use App\Component\Spool\Domain\SpoolDataMapper;
use App\Component\Spool\Domain\SpoolRepository;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
class SpoolDatabaseAdapter extends ServiceEntityRepository implements SpoolDataMapper, SpoolRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Spool::class);
}
public function findById(int $id): Spool
{
// TODO: Implement findById() method.
}
public function findAll() : array
{
}
}

View File

@ -21,10 +21,7 @@ class User
#[ORM\Column(type:Types::STRING, length:255)] #[ORM\Column(type:Types::STRING, length:255)]
private string $firstname; private string $firstname;
#[ORM\OneToOne(mappedBy:"role", targetEntity: Role::class)] #[ORM\ManyToOne(targetEntity: Role::class, inversedBy:"users")]
#[ORM\JoinTable(name:"roles")]
#[ORM\JoinColumn(name: "role_id", referencedColumnName: "id")]
#[ORM\InverseJoinColumn(name: "id", referencedColumnName: "role_id")]
protected Role $role; protected Role $role;
#[ORM\Column(type:Types::DECIMAL,length:10, precision:2)] #[ORM\Column(type:Types::DECIMAL,length:10, precision:2)]

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\UserMaterial\Domain;
class UserMaterial
{
}

View File

@ -0,0 +1,8 @@
<?php
namespace App\Component\UserMaterial\Domain;
interface UserMaterialDataMapper
{
}

View File

@ -0,0 +1,9 @@
<?php
namespace App\Component\UserMaterial\Domain;
interface UserMaterialRepository
{
public function findById(int $id): UserMaterial;
public function findAll(): array;
}

View File

@ -0,0 +1,28 @@
<?php
namespace App\Component\UserMaterial\Infrastructure;
use App\Component\UserMaterial\Domain\UserMaterial;
use App\Component\UserMaterial\Domain\UserMaterialDataMapper;
use App\Component\UserMaterial\Domain\UserMaterialRepository;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
class UserMaterialDatabaseAdapter extends ServiceEntityRepository implements UserMaterialDataMapper, UserMaterialRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, UserMaterial::class);
}
public function findById(int $id): UserMaterial
{
// TODO: Implement findById() method.
}
public function findAll(): array
{
// TODO: Implement findAll() method.
}
}

View File

@ -2,6 +2,7 @@
namespace App\Controller; namespace App\Controller;
use App\Component\Order\Infrastructure\OrderDatabaseAdapter;
use App\Component\Role\Infrastructure\RoleDatabaseAdapter; use App\Component\Role\Infrastructure\RoleDatabaseAdapter;
use App\Component\User\Infrastructure\UserDatabaseAdapter; use App\Component\User\Infrastructure\UserDatabaseAdapter;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
@ -20,6 +21,7 @@ class TestController extends AbstractController
public function index(UserDatabaseAdapter $DoctrineUser): Response public function index(UserDatabaseAdapter $DoctrineUser): Response
{ {
$user = $DoctrineUser->findById(1); $user = $DoctrineUser->findById(1);
dd($user->getRole()->getUsers());
return new Response( return new Response(
$user->getId(). " " .$user->getName(), $user->getId(). " " .$user->getName(),
Response::HTTP_OK, Response::HTTP_OK,