L'architecture hexagonale ... concrètement
AFUP Day 11/06/2021 - Toulouse
Architecture hexagonale
- Présentation du concept
- Mise en place
- Exemple d'implémentation
- Aller plus loin
Problème
- “Ah, si on pouvait utiliser XXX ! ça a l’air trop bien !”
- “Oui, mais vu tout ce qu’il faudrait réécrire ...”
XXX = nouvelle lib / service / framework
Solution universelle
data:image/s3,"s3://crabby-images/1e1d2/1e1d269a342c132d440bfda34f508500ae2cb0e3" alt="briques"
Version architecture hexagonale
data:image/s3,"s3://crabby-images/a16d2/a16d22f276811072f582054fc1f0d57e3319b60a" alt="ports"
Architecture hexagonale
data:image/s3,"s3://crabby-images/5483f/5483f8f67b6a10f5460cee827e7d6b4ad1a606f5" alt="hexagon"
Avantages
- Choix infrastructure plus tard
- Démo plus rapidement
- Montées de versions framework et lib plus faciles
- Bascule facile vers nouvelles lib / services
- Tests plus simples à écrire
Attention
- un peu plus de code à écrire
- outils de génération de code ne fonctionnent pas tous
⇒ à réserver aux applications complexes… ou qui vont le devenir
Exemple
Lien vers repo à la fin
Avec Symfony… car + utilisé et s’y prête bien
C'est une des implémentations possibles
Mise en place : étape 1
Modification autoload dans composer.json
data:image/s3,"s3://crabby-images/d9068/d90683fbe3cfab83742ef7dc56daf539488197cc" alt="changes composer"
Etape 2 : déplacement du Kernel
src/Kernel.php ⇒ src/Infrastructure/Symfony/Kernel.php
- Corriger chemin vers config
- Corriger instanciations dans :
- bin/console
- public/index.php
- .env.test
Etape 3 : configuration services
services:
Domain\:
resource: '../src/Domain'
exclude:
- '../src/Domain/Entity/'
Infrastructure\:
resource: '../src/Infrastructure'
exclude:
- '../src/Infrastructure/Symfony/Kernel.php'
Infrastructure\Symfony\Controller\:
resource: '../src/Infrastructure/Symfony/Controller/'
tags: ['controller.service_arguments']
Domain
- Organisation métier
- Interface pour chaque besoin
- Tests 100% coverage
Infrastructure
- Organisation technique
- Implémenter interfaces
Exemple Interface du Domain
Exemple Infrastructure Tests
Infrastructure controller
Outil
Deptrac : github.com/qossmic/deptrac
Règles :
- Domain n’utilise pas Infrastructure
- Domain n’utilise aucun namespace externe
(ex: Symfony, Doctrine, etc.)
Communication entre contextes
- par API
- par event (message bus)
Couches supplémentaires
- src
- [Contexte 1]
- Application
- Domain
- Infrastructure
Dans un legacy ?
- Créer dossiers Domain et Infrastructure
- Nouvelles fonctionnalités dans hexagonal
- Migration progressive pour l'existant