123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- <?php
- namespace Gedmo\Sluggable\Mapping\Event\Adapter;
- use Gedmo\Mapping\Event\Adapter\ODM as BaseAdapterODM;
- use Doctrine\Common\Persistence\Mapping\ClassMetadata;
- use Doctrine\ODM\MongoDB\Cursor;
- use Gedmo\Sluggable\Mapping\Event\SluggableAdapter;
- use Gedmo\Tool\Wrapper\AbstractWrapper;
- /**
- * Doctrine event adapter for ODM adapted
- * for sluggable behavior
- *
- * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
- * @package Gedmo\Sluggable\Mapping\Event\Adapter
- * @subpackage ODM
- * @link http://www.gediminasm.org
- * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
- */
- final class ODM extends BaseAdapterODM implements SluggableAdapter
- {
- /**
- * {@inheritDoc}
- */
- public function getSimilarSlugs($object, ClassMetadata $meta, array $config, $slug)
- {
- $dm = $this->getObjectManager();
- $qb = $dm->createQueryBuilder($config['useObjectClass']);
- $identifier = $this->extractIdentifier($dm, $object);
- if ($identifier) {
- $qb->field($meta->identifier)->notEqual($identifier);
- }
- $qb->field($config['slug'])->Equals(new \MongoRegex('/^' . str_replace('/', '\/', $slug) . '/'));
- $q = $qb->getQuery();
- $q->setHydrate(false);
- $result = $q->execute();
- if ($result instanceof Cursor) {
- $result = $result->toArray();
- }
- return $result;
- }
- /**
- * This query can couse some data integrity failures since it does not
- * execute atomicaly
- *
- * {@inheritDoc}
- */
- public function replaceRelative($object, array $config, $target, $replacement)
- {
- $dm = $this->getObjectManager();
- $meta = $dm->getClassMetadata($config['useObjectClass']);
- $q = $dm
- ->createQueryBuilder($config['useObjectClass'])
- ->where("function() {
- return this.{$config['slug']}.indexOf('{$target}') === 0;
- }")
- ->getQuery()
- ;
- $q->setHydrate(false);
- $result = $q->execute();
- if ($result instanceof Cursor) {
- $result = $result->toArray();
- foreach ($result as $targetObject) {
- $slug = preg_replace("@^{$target}@smi", $replacement.$config['pathSeparator'], $targetObject[$config['slug']]);
- $dm
- ->createQueryBuilder()
- ->update($config['useObjectClass'])
- ->field($config['slug'])->set($slug)
- ->field($meta->identifier)->equals($targetObject['_id'])
- ->getQuery()
- ->execute()
- ;
- }
- }
- }
- /**
- * This query can couse some data integrity failures since it does not
- * execute atomicaly
- *
- * {@inheritDoc}
- */
- public function replaceInverseRelative($object, array $config, $target, $replacement)
- {
- $dm = $this->getObjectManager();
- $wrapped = AbstractWrapper::wrapp($object, $dm);
- $meta = $dm->getClassMetadata($config['useObjectClass']);
- $q = $dm
- ->createQueryBuilder($config['useObjectClass'])
- ->field($config['mappedBy'].'.'.$meta->identifier)->equals($wrapped->getIdentifier())
- ->getQuery()
- ;
- $q->setHydrate(false);
- $result = $q->execute();
- if ($result instanceof Cursor) {
- $result = $result->toArray();
- foreach ($result as $targetObject) {
- $slug = preg_replace("@^{$replacement}@smi", $target, $targetObject[$config['slug']]);
- $dm
- ->createQueryBuilder()
- ->update($config['useObjectClass'])
- ->field($config['slug'])->set($slug)
- ->field($meta->identifier)->equals($targetObject['_id'])
- ->getQuery()
- ->execute()
- ;
- }
- }
- }
- }
|