src/Repository/Doctrine/DoctrineResearchRepository.php
<?php
declare(strict_types=1);
namespace FrankProjects\UltimateWarfare\Repository\Doctrine;
use Doctrine\ORM\EntityManagerInterface;
use Doctrine\ORM\EntityRepository;
use FrankProjects\UltimateWarfare\Entity\Player;
use FrankProjects\UltimateWarfare\Entity\Research;
use FrankProjects\UltimateWarfare\Entity\ResearchPlayer;
use FrankProjects\UltimateWarfare\Repository\ResearchRepository;
final class DoctrineResearchRepository implements ResearchRepository
{
private EntityManagerInterface $entityManager;
/**
* @var EntityRepository <Research>
*/
private EntityRepository $repository;
public function __construct(EntityManagerInterface $entityManager)
{
$this->entityManager = $entityManager;
$this->repository = $this->entityManager->getRepository(Research::class);
}
public function find(int $id): ?Research
{
return $this->repository->find($id);
}
/**
* @return Research[]
*/
public function findAll(): array
{
return $this->repository->findAll();
}
/**
* @param Player $player
* @return Research[]
*/
public function findOngoingByPlayer(Player $player): array
{
return $this->entityManager->createQuery(
'SELECT rp
FROM ' . ResearchPlayer::class . ' rp
JOIN ' . Research::class . ' r WITH rp.research = r
WHERE rp.player = :player AND rp.active = 0'
)->setParameter(
'player',
$player
)->getResult();
}
/**
* @param Player $player
* @return Research[]
*/
public function findUnresearchedByPlayer(Player $player): array
{
return $this->entityManager->createQuery(
'SELECT r
FROM ' . Research::class . ' r
WHERE r.active = 1 AND r.id NOT IN (SELECT r2.id FROM ' . ResearchPlayer::class . ' rp JOIN rp.research r2 WHERE rp.player = :player)'
)->setParameter(
'player',
$player
)->getResult();
}
public function remove(Research $research): void
{
$this->entityManager->remove($research);
$this->entityManager->flush();
}
public function save(Research $research): void
{
$this->entityManager->persist($research);
$this->entityManager->flush();
}
}