| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 | 
							- <?php
 - 
 - namespace Gedmo\Sluggable\Handler;
 - 
 - use Doctrine\Common\Persistence\ObjectManager;
 - use Gedmo\Sluggable\SluggableListener;
 - use Gedmo\Sluggable\Mapping\Event\SluggableAdapter;
 - use Gedmo\Tool\Wrapper\AbstractWrapper;
 - use Gedmo\Exception\InvalidMappingException;
 - use Doctrine\Common\Persistence\Mapping\ClassMetadata;
 - 
 - /**
 - * Sluggable handler which should be used for inversed relation mapping
 - * used together with RelativeSlugHandler. Updates back related slug on
 - * relation changes
 - *
 - * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
 - * @package Gedmo.Sluggable.Handler
 - * @subpackage InversedRelativeSlugHandler
 - * @link http://www.gediminasm.org
 - * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
 - */
 - class InversedRelativeSlugHandler implements SlugHandlerInterface
 - {
 -     /**
 -      * @var ObjectManager
 -      */
 -     protected $om;
 - 
 -     /**
 -      * @var SluggableListener
 -      */
 -     protected $sluggable;
 - 
 -     /**
 -      * $options = array(
 -      *     'relationClass' => 'objectclass',
 -      *     'inverseSlugField' => 'slug',
 -      *     'mappedBy' => 'relationField'
 -      * )
 -      * {@inheritDoc}
 -      */
 -     public function __construct(SluggableListener $sluggable)
 -     {
 -         $this->sluggable = $sluggable;
 -     }
 - 
 -     /**
 -      * {@inheritDoc}
 -      */
 -     public function onChangeDecision(SluggableAdapter $ea, $slugFieldConfig, $object, &$slug, &$needToChangeSlug)
 -     {}
 - 
 -     /**
 -      * {@inheritDoc}
 -      */
 -     public function postSlugBuild(SluggableAdapter $ea, array &$config, $object, &$slug)
 -     {}
 - 
 -     /**
 -      * {@inheritDoc}
 -      */
 -     public static function validate(array $options, ClassMetadata $meta)
 -     {
 -         if (!isset($options['relationClass']) || !strlen($options['relationClass'])) {
 -             throw new InvalidMappingException("'relationClass' option must be specified for object slug mapping - {$meta->name}");
 -         }
 -         if (!isset($options['mappedBy']) || !strlen($options['mappedBy'])) {
 -             throw new InvalidMappingException("'mappedBy' option must be specified for object slug mapping - {$meta->name}");
 -         }
 -         if (!isset($options['inverseSlugField']) || !strlen($options['inverseSlugField'])) {
 -             throw new InvalidMappingException("'inverseSlugField' option must be specified for object slug mapping - {$meta->name}");
 -         }
 -     }
 - 
 -     /**
 -      * {@inheritDoc}
 -      */
 -     public function onSlugCompletion(SluggableAdapter $ea, array &$config, $object, &$slug)
 -     {
 -         $this->om = $ea->getObjectManager();
 -         $isInsert = $this->om->getUnitOfWork()->isScheduledForInsert($object);
 -         if (!$isInsert) {
 -             $options = $config['handlers'][get_called_class()];
 -             $wrapped = AbstractWrapper::wrap($object, $this->om);
 -             $oldSlug = $wrapped->getPropertyValue($config['slug']);
 -             $mappedByConfig = $this->sluggable->getConfiguration(
 -                 $this->om,
 -                 $options['relationClass']
 -             );
 -             if ($mappedByConfig) {
 -                 $meta = $this->om->getClassMetadata($options['relationClass']);
 -                 if (!$meta->isSingleValuedAssociation($options['mappedBy'])) {
 -                     throw new InvalidMappingException("Unable to find ".$wrapped->getMetadata()->name." relation - [{$options['mappedBy']}] in class - {$meta->name}");
 -                 }
 -                 if (!isset($mappedByConfig['slugs'][$options['inverseSlugField']])) {
 -                     throw new InvalidMappingException("Unable to find slug field - [{$options['inverseSlugField']}] in class - {$meta->name}");
 -                 }
 -                 $mappedByConfig['slug'] = $mappedByConfig['slugs'][$options['inverseSlugField']]['slug'];
 -                 $mappedByConfig['mappedBy'] = $options['mappedBy'];
 -                 $ea->replaceInverseRelative($object, $mappedByConfig, $slug, $oldSlug);
 -                 $uow = $this->om->getUnitOfWork();
 -                 // update in memory objects
 -                 foreach ($uow->getIdentityMap() as $className => $objects) {
 -                     // for inheritance mapped classes, only root is always in the identity map
 -                     if ($className !== $mappedByConfig['useObjectClass']) {
 -                         continue;
 -                     }
 -                     foreach ($objects as $object) {
 -                         if (property_exists($object, '__isInitialized__') && !$object->__isInitialized__) {
 -                             continue;
 -                         }
 -                         $oid = spl_object_hash($object);
 -                         $objectSlug = $meta->getReflectionProperty($mappedByConfig['slug'])->getValue($object);
 -                         if (preg_match("@^{$oldSlug}@smi", $objectSlug)) {
 -                             $objectSlug = str_replace($oldSlug, $slug, $objectSlug);
 -                             $meta->getReflectionProperty($mappedByConfig['slug'])->setValue($object, $objectSlug);
 -                             $ea->setOriginalObjectProperty($uow, $oid, $mappedByConfig['slug'], $objectSlug);
 -                         }
 -                     }
 -                 }
 -             }
 -         }
 -     }
 - 
 -     /**
 -      * {@inheritDoc}
 -      */
 -     public function handlesUrlization()
 -     {
 -         return false;
 -     }
 - }
 
 
  |