refactor(core) : isole Core du module Sites via SiteProviderInterface + resolve_target_entities
Supprime les imports directs de App\Module\Sites\* depuis le module Core : - SiteProviderInterface (Shared/Contract) : contrat minimal findByName(), etendu par SiteRepositoryInterface pour reutilisation DI. - AppFixtures : injecte SiteProviderInterface au lieu de SiteRepositoryInterface. - User.php : targetEntity des mappings ORM pointe desormais sur SiteInterface, resolu a la classe concrete via doctrine.orm.resolve_target_entities (pattern officiel Doctrine pour les bounded contexts DDD). - JoinColumn/InverseJoinColumn explicites sur la ManyToMany user_site pour forcer les noms de colonnes (sinon Doctrine derive site_interface_id). Respecte la regle CLAUDE.md "jamais d'import direct entre modules" — il reste l'exception SitesFixtures::class dans getDependencies() (contrainte d'API DependentFixtureInterface, meme registre que resolve_target_entities). Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -8,9 +8,9 @@ use App\Module\Core\Domain\Entity\Role;
|
||||
use App\Module\Core\Domain\Entity\User;
|
||||
use App\Module\Core\Domain\Repository\RoleRepositoryInterface;
|
||||
use App\Module\Core\Domain\Security\SystemRoles;
|
||||
use App\Module\Sites\Domain\Entity\Site;
|
||||
use App\Module\Sites\Domain\Repository\SiteRepositoryInterface;
|
||||
use App\Module\Sites\Infrastructure\DataFixtures\SitesFixtures;
|
||||
use App\Shared\Domain\Contract\SiteInterface;
|
||||
use App\Shared\Domain\Contract\SiteProviderInterface;
|
||||
use Doctrine\Bundle\FixturesBundle\Fixture;
|
||||
use Doctrine\Common\DataFixtures\DependentFixtureInterface;
|
||||
use Doctrine\Persistence\ObjectManager;
|
||||
@@ -39,7 +39,7 @@ class AppFixtures extends Fixture implements DependentFixtureInterface
|
||||
public function __construct(
|
||||
private readonly UserPasswordHasherInterface $passwordHasher,
|
||||
private readonly RoleRepositoryInterface $roleRepository,
|
||||
private readonly SiteRepositoryInterface $siteRepository,
|
||||
private readonly SiteProviderInterface $siteProvider,
|
||||
) {}
|
||||
|
||||
/**
|
||||
@@ -135,9 +135,9 @@ class AppFixtures extends Fixture implements DependentFixtureInterface
|
||||
return $role;
|
||||
}
|
||||
|
||||
private function requireSite(string $name): Site
|
||||
private function requireSite(string $name): SiteInterface
|
||||
{
|
||||
$site = $this->siteRepository->findByName($name);
|
||||
$site = $this->siteProvider->findByName($name);
|
||||
|
||||
if (null === $site) {
|
||||
throw new RuntimeException(sprintf(
|
||||
|
||||
Reference in New Issue
Block a user