ユーザーがページを作成できる小さな symfony2 アプリケーションがあります。各ページはルート /{user_slug}/{page_slug} 経由でアクセスできる必要があります。ユーザーとページのエンティティがあり、両方のエンティティにスラッグ可能な動作を使用します。正しいページを見つけるには、user_slug と page_slug の組み合わせが一意である必要があります。
user_slug と page_slug の組み合わせが一意であることを確認する最良の方法は何ですか?
前置詞でこれを試してください:
public function findByUsernameAndSlug($username, $slug)
{
$em = $this->getEntityManager();
$query = $em->createQuery("
SELECT g
FROM Acme\PagesBundle\Entity\Page p
JOIN p.owner u
WHERE u.username = :username
AND p.slug = :slug
")
->setParameter('username', $username)
->setParameter('slug', $slug);
foreach ($query->getResult() as $goal) {
return $goal;
}
return null;
}
サービス層でエンティティを永続化する前に、指定されたユーザーとページ スラッグの組み合わせが一意であるかどうかを確認します。そうでない場合は、ページ スラッグを変更 (追加-2
など) するか、例外をスローします。
public function persistPage(Page $page) {
$userSlug = $page->getUser()->getSlug();
$pageSlug = $page->getSlug();
if ($this->pagesRepository->findOneBySlugs($userSlug, $pageSlug) != null) {
// given combination already exists
throw new NonUniqueNameException(..);
// or modify the slug
$page->setSlug($page->getSlug() . '-2');
return $this->persistPage($page);
}
return $this->em->persist($page);
}
// PagesRepository::findOneBySlugs($userSlug, $pageSlug)
public function findOneBySlugs($userSlug, $pageSlug) {
$query = $this->em->createQueryBuilder('p')
->addSelect('u')
->join('p.user', 'u')
->where('p.slug = :pageSlug')
->where('u.slug = :userSlug;)
->getQuery();
$query->setParameters(combine('userSlug', 'pageSlug'));
return $query->getSingleResult();
}