Dieser Artikel untersucht ein Domain-Driven Design (DDD)-Anwendungsfallmodell in PHP und zeigt, wie Schnittstellen und domänenspezifische Klassen zur Verwaltung der Datenpersistenz verwendet werden. Wir untersuchen die Klasse TaxPersistUseCase, die einen Persistenzmanager (TaxManagerInterface) verwendet, um eine Entität vom Typ Tax zu speichern, die eine Steuer darstellt.
Dieses Modell betont die DDD-Prinzipien: Jede Komponente ist klar in Schnittstellen, konkrete Implementierungen und Ausnahmen unterteilt, wobei Best Practices bei der Abhängigkeitsinjektion und Fehlerbehandlung befolgt werden.
Die TaxPersistUseCase-Klasse verwaltet die Geschäftslogik, die mit der Beibehaltung einer Steuer verbunden ist. Es ist in mehrere Abschnitte unterteilt, um die Logik und Struktur dieses Ansatzes zu verdeutlichen.
namespace Domain\Application\UseCase\Order; use Domain\Application\Entity\Order\Tax; use Domain\Application\Gateway\Manager\Order\TaxManagerInterface; use Domain\Application\UseCase\Order\Exception\NotFoundException; use Domain\Application\UseCase\Order\Interfaces\TaxPersistRequestInterface; use Domain\Application\UseCase\Order\Interfaces\TaxPersistResponseInterface; use Domain\Exception\BadRequestException; use Domain\Exception\FormException; use Small\CleanApplication\Contract\UseCaseInterface; use Small\Collection\Collection\StringCollection; use Small\SwooleEntityManager\EntityManager\Exception\EmptyResultException;
Die TaxPersistUseCase-Klasse hängt von mehreren Schnittstellen und Ausnahmen ab, um die Steuerpersistenz zu handhaben. Hier ist eine Aufschlüsselung ihrer Rollen:
TaxPersistRequestInterface und TaxPersistResponseInterface: Schnittstellen für die Anfrage und Antwort des Anwendungsfalls.
Ausnahmen: Verschiedene Ausnahmen wie BadRequestException, FormException und NotFoundException helfen bei der Verwaltung kontextspezifischer Fehler.
namespace Domain\Application\UseCase\Order; use Domain\Application\Entity\Order\Tax; use Domain\Application\Gateway\Manager\Order\TaxManagerInterface; use Domain\Application\UseCase\Order\Exception\NotFoundException; use Domain\Application\UseCase\Order\Interfaces\TaxPersistRequestInterface; use Domain\Application\UseCase\Order\Interfaces\TaxPersistResponseInterface; use Domain\Exception\BadRequestException; use Domain\Exception\FormException; use Small\CleanApplication\Contract\UseCaseInterface; use Small\Collection\Collection\StringCollection; use Small\SwooleEntityManager\EntityManager\Exception\EmptyResultException;
Die Schnittstellen definieren die Verträge, die jede Komponente einhalten muss, und fördern so die Entkopplung und Testbarkeit.
Diese Schnittstelle spezifiziert die Methoden zur Verwaltung von Steuern, einschließlich Abruf und Persistenz:
class TaxPersistUseCase implements UseCaseInterface { public function __construct( protected TaxManagerInterface $taxManager, ) {} public function execute(mixed $request): TaxPersistResponseInterface { if (!$request instanceof TaxPersistRequestInterface) { throw new BadRequestException( self::class . ' accepts only request instance of ' . TaxPersistRequestInterface::class ); } $tax = $request->getTax(); $messages = new StringCollection(); try { $this->taxManager->applicationPersist($tax); } catch (EmptyResultException $e) { throw new NotFoundException($e->getMessage()); } catch (FormException $e) { $messages = $e->getFormMessages(); } return new class($tax, $messages) implements TaxPersistResponseInterface { public function __construct( protected readonly Tax $tax, protected readonly StringCollection $messages, ) {} public function getTax(): Tax { return $this->tax; } public function getMessages(): StringCollection { return $this->messages; } }; } }
Diese Schnittstelle definiert die Struktur der von TaxPersistUseCase erwarteten Anforderung:
interface TaxManagerInterface { public function findById(int $id): Tax; public function findByName(string $name): Tax; public function applicationPersist(Tax $tax): self; }
interface TaxPersistRequestInterface extends RequestInterface { public function getTax(): Tax; }
Ausnahmen spielen bei DDD eine wichtige Rolle, indem sie domänenspezifische Fehler erfassen:
Das obige ist der detaillierte Inhalt vonImplementierung eines DDD-Anwendungsfalls in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!