AbstractTreeRepository.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. namespace Gedmo\Tree\Document\MongoDB\Repository;
  3. use Doctrine\ODM\MongoDB\DocumentRepository,
  4. Doctrine\ODM\MongoDB\DocumentManager,
  5. Doctrine\ODM\MongoDB\Mapping\ClassMetadata,
  6. Doctrine\ODM\MongoDB\UnitOfWork;
  7. abstract class AbstractTreeRepository extends DocumentRepository
  8. {
  9. /**
  10. * Tree listener on event manager
  11. *
  12. * @var AbstractTreeListener
  13. */
  14. protected $listener = null;
  15. /**
  16. * {@inheritdoc}
  17. */
  18. public function __construct(DocumentManager $em, UnitOfWork $uow, ClassMetadata $class)
  19. {
  20. parent::__construct($em, $uow, $class);
  21. $treeListener = null;
  22. foreach ($em->getEventManager()->getListeners() as $listeners) {
  23. foreach ($listeners as $listener) {
  24. if ($listener instanceof \Gedmo\Tree\TreeListener) {
  25. $treeListener = $listener;
  26. break;
  27. }
  28. }
  29. if ($treeListener) {
  30. break;
  31. }
  32. }
  33. if (is_null($treeListener)) {
  34. throw new \Gedmo\Exception\InvalidMappingException('This repository can be attached only to ODM MongoDB tree listener');
  35. }
  36. $this->listener = $treeListener;
  37. if (!$this->validates()) {
  38. throw new \Gedmo\Exception\InvalidMappingException('This repository cannot be used for tree type: ' . $treeListener->getStrategy($em, $class->name)->getName());
  39. }
  40. }
  41. /**
  42. * Checks if current repository is right
  43. * for currently used tree strategy
  44. *
  45. * @return bool
  46. */
  47. abstract protected function validates();
  48. }