ORM.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. namespace Gedmo\Sluggable\Mapping\Event\Adapter;
  3. use Gedmo\Mapping\Event\Adapter\ORM as BaseAdapterORM;
  4. use Doctrine\Common\Persistence\Mapping\ClassMetadata;
  5. use Doctrine\ORM\Query;
  6. use Gedmo\Sluggable\Mapping\Event\SluggableAdapter;
  7. /**
  8. * Doctrine event adapter for ORM adapted
  9. * for sluggable behavior
  10. *
  11. * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
  12. * @package Gedmo\Sluggable\Mapping\Event\Adapter
  13. * @subpackage ORM
  14. * @link http://www.gediminasm.org
  15. * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
  16. */
  17. final class ORM extends BaseAdapterORM implements SluggableAdapter
  18. {
  19. /**
  20. * {@inheritDoc}
  21. */
  22. public function getSimilarSlugs($object, ClassMetadata $meta, array $config, $slug)
  23. {
  24. $em = $this->getObjectManager();
  25. $qb = $em->createQueryBuilder();
  26. $qb->select('rec.' . $config['slug'])
  27. ->from($config['useObjectClass'], 'rec')
  28. ->where($qb->expr()->like(
  29. 'rec.' . $config['slug'],
  30. $qb->expr()->literal($slug . '%'))
  31. );
  32. // include identifiers
  33. $entityIdentifiers = $this->extractIdentifier($em, $object, false);
  34. $parameters = array();
  35. foreach ((array)$entityIdentifiers as $field => $value) {
  36. if (strlen($value)) {
  37. $qb->andWhere('rec.' . $field . ' <> :' . $field);
  38. $parameters[$field] = $value;
  39. }
  40. }
  41. $q = $qb->getQuery();
  42. if ($parameters) {
  43. $q->setParameters($parameters);
  44. }
  45. $q->setHydrationMode(Query::HYDRATE_ARRAY);
  46. return $q->execute();
  47. }
  48. public function replaceRelative($object, array $config, $target, $replacement)
  49. {
  50. $em = $this->getObjectManager();
  51. $qb = $em->createQueryBuilder();
  52. $qb->update($config['useObjectClass'], 'rec')
  53. ->set('rec.'.$config['slug'], $qb->expr()->concat(
  54. $qb->expr()->literal($replacement),
  55. $qb->expr()->substring('rec.'.$config['slug'], strlen($target))
  56. ))
  57. ->where($qb->expr()->like(
  58. 'rec.'.$config['slug'],
  59. $qb->expr()->literal($target . '%'))
  60. )
  61. ;
  62. // update in memory
  63. $q = $qb->getQuery();
  64. return $q->execute();
  65. }
  66. }