コード例 #1
0
ファイル: UnitOfWork.php プロジェクト: kevinyien/mongodb-odm
 /**
  * Executes all document deletions for documents of the specified type.
  *
  * @param ClassMetadata $class
  * @param array $documents Array of documents to delete
  * @param array $options Array of options to be used with remove()
  */
 private function executeDeletions(ClassMetadata $class, array $documents, array $options = array())
 {
     $hasPostRemoveLifecycleCallbacks = !empty($class->lifecycleCallbacks[Events::postRemove]);
     $hasPostRemoveListeners = $this->evm->hasListeners(Events::postRemove);
     $persister = $this->getDocumentPersister($class->name);
     foreach ($documents as $oid => $document) {
         if (!$class->isEmbeddedDocument) {
             $persister->delete($document, $options);
         }
         unset($this->documentDeletions[$oid], $this->documentIdentifiers[$oid], $this->originalDocumentData[$oid]);
         // Clear snapshot information for any referenced PersistentCollection
         // http://www.doctrine-project.org/jira/browse/MODM-95
         foreach ($class->associationMappings as $fieldMapping) {
             if (isset($fieldMapping['type']) && $fieldMapping['type'] === ClassMetadata::MANY) {
                 $value = $class->reflFields[$fieldMapping['fieldName']]->getValue($document);
                 if ($value instanceof PersistentCollection) {
                     $value->clearSnapshot();
                 }
             }
         }
         // Document with this $oid after deletion treated as NEW, even if the $oid
         // is obtained by a new document because the old one went out of scope.
         $this->documentStates[$oid] = self::STATE_NEW;
         if ($hasPostRemoveLifecycleCallbacks) {
             $class->invokeLifecycleCallbacks(Events::postRemove, $document);
         }
         if ($hasPostRemoveListeners) {
             $this->evm->dispatchEvent(Events::postRemove, new LifecycleEventArgs($document, $this->dm));
         }
     }
 }
コード例 #2
0
 /**
  * Executes all document deletions for documents of the specified type.
  *
  * @param Doctrine\ODM\MongoDB\Mapping\ClassMetadata $class
  */
 private function _executeDeletions($class)
 {
     $hasLifecycleCallbacks = isset($class->lifecycleCallbacks[Events::postRemove]);
     $hasListeners = $this->_evm->hasListeners(Events::postRemove);
     $className = $class->name;
     $persister = $this->getDocumentPersister($className);
     $collection = $this->_dm->getDocumentCollection($className);
     foreach ($this->_documentDeletions as $oid => $document) {
         if (get_class($document) == $className || $document instanceof Proxy && $document instanceof $className) {
             $persister->delete($document);
             unset($this->_documentDeletions[$oid], $this->_documentIdentifiers[$oid], $this->_originalDocumentData[$oid]);
             // Document with this $oid after deletion treated as NEW, even if the $oid
             // is obtained by a new document because the old one went out of scope.
             $this->_documentStates[$oid] = self::STATE_NEW;
             if ($hasLifecycleCallbacks) {
                 $class->invokeLifecycleCallbacks(Events::postRemove, $document);
             }
             if ($hasListeners) {
                 $this->_evm->dispatchEvent(Events::postRemove, new LifecycleEventArgs($document, $this->_dm));
             }
         }
     }
 }
コード例 #3
0
ファイル: UnitOfWork.php プロジェクト: nextmotion/mongodb-odm
 /**
  * Executes all document insertions for documents of the specified type.
  *
  * @param Doctrine\ODM\MongoDB\Mapping\ClassMetadata $class
  * @param array $options Array of options to be used with batchInsert()
  */
 private function executeInserts($class, array $options = array())
 {
     $className = $class->name;
     $persister = $this->getDocumentPersister($className);
     $collection = $this->dm->getDocumentCollection($className);
     $hasLifecycleCallbacks = isset($class->lifecycleCallbacks[Events::postPersist]);
     $hasListeners = $this->evm->hasListeners(Events::postPersist);
     if ($hasLifecycleCallbacks || $hasListeners) {
         $documents = array();
     }
     $inserts = array();
     foreach ($this->documentInsertions as $oid => $document) {
         if (get_class($document) === $className) {
             $persister->addInsert($document);
             unset($this->documentInsertions[$oid]);
             if ($hasLifecycleCallbacks || $hasListeners) {
                 $documents[] = $document;
             }
         }
     }
     $postInsertIds = $persister->executeInserts($options);
     if ($postInsertIds) {
         foreach ($postInsertIds as $pair) {
             list($id, $document) = $pair;
             $oid = spl_object_hash($document);
             $class->setIdentifierValue($document, $id);
             $this->documentIdentifiers[$oid] = $id;
             $this->documentStates[$oid] = self::STATE_MANAGED;
             $this->originalDocumentData[$oid][$class->identifier] = $id;
             $this->addToIdentityMap($document);
             if ($hasLifecycleCallbacks || $hasListeners) {
                 if ($hasLifecycleCallbacks) {
                     $class->invokeLifecycleCallbacks(Events::postPersist, $document);
                 }
                 if ($hasListeners) {
                     $this->evm->dispatchEvent(Events::postPersist, new LifecycleEventArgs($document, $this->dm));
                 }
             }
             $this->cascadePostPersist($class, $document);
         }
     }
 }
コード例 #4
0
 /**
  * Invokes preUpdate callbacks and events for given document cascading them to embedded documents as well.
  *
  * @param ClassMetadata $class
  * @param object $document
  */
 public function preUpdate(ClassMetadata $class, $document)
 {
     if (!empty($class->lifecycleCallbacks[Events::preUpdate])) {
         $class->invokeLifecycleCallbacks(Events::preUpdate, $document, array(new PreUpdateEventArgs($document, $this->dm, $this->uow->getDocumentChangeSet($document))));
         $this->uow->recomputeSingleDocumentChangeSet($class, $document);
     }
     $this->evm->dispatchEvent(Events::preUpdate, new PreUpdateEventArgs($document, $this->dm, $this->uow->getDocumentChangeSet($document)));
     $this->cascadePreUpdate($class, $document);
 }