. */ namespace Doctrine\ORM\Mapping; /** * A one-to-one mapping describes a uni-directional mapping from one entity * to another entity. * * @since 2.0 * @author Roman Borschel */ class OneToOneMapping extends AssociationMapping { /** * Maps the source foreign/primary key columns to the target primary/foreign key columns. * i.e. source.id (pk) => target.user_id (fk). * Reverse mapping of _targetToSourceKeyColumns. */ protected $_sourceToTargetKeyColumns = array(); /** * Maps the target primary/foreign key columns to the source foreign/primary key columns. * i.e. target.user_id (fk) => source.id (pk). * Reverse mapping of _sourceToTargetKeyColumns. */ protected $_targetToSourceKeyColumns = array(); /** * Whether to delete orphaned elements (when nulled out, i.e. $foo->other = null) * * @var boolean */ protected $_deleteOrphans = false; /** * Creates a new OneToOneMapping. * * @param array $mapping The mapping info. */ public function __construct(array $mapping) { parent::__construct($mapping); } /** * {@inheritdoc} * * @param array $mapping The mapping to validate & complete. * @return array The validated & completed mapping. * @override */ protected function _validateAndCompleteMapping(array $mapping) { parent::_validateAndCompleteMapping($mapping); if ($this->isOwningSide()) { if ( ! isset($mapping['joinColumns'])) { throw Doctrine_ORM_Exceptions_MappingException::invalidMapping($this->_sourceFieldName); } $this->_sourceToTargetKeyColumns = $mapping['joinColumns']; $this->_targetToSourceKeyColumns = array_flip($this->_sourceToTargetKeyColumns); } $this->_deleteOrphans = isset($mapping['deleteOrphans']) ? (bool)$mapping['deleteOrphans'] : false; return $mapping; } /** * Gets the source-to-target key column mapping. * * @return array */ public function getSourceToTargetKeyColumns() { return $this->_sourceToTargetKeyColumns; } /** * Gets the target-to-source key column mapping. * * @return array */ public function getTargetToSourceKeyColumns() { return $this->_targetToSourceKeyColumns; } /** * {@inheritdoc} * * @return boolean * @override */ public function isOneToOne() { return true; } /** * {@inheritdoc} * * @param Doctrine\ORM\Entity $entity * @return void */ public function lazyLoadFor($entity, $entityManager) { $sourceClass = $entityManager->getClassMetadata($this->_sourceEntityName); $targetClass = $entityManager->getClassMetadata($this->_targetEntityName); $dql = 'SELECT t FROM ' . $targetClass->getClassName() . ' t WHERE '; $params = array(); foreach ($this->_sourceToTargetKeyFields as $sourceKeyField => $targetKeyField) { if ($params) $dql .= " AND "; $dql .= "t.$targetKeyField = ?"; $params[] = $sourceClass->getReflectionProperty($sourceKeyField)->getValue($entity); } $otherEntity = $entityManager->query($dql, $params)->getFirst(); if ( ! $otherEntity) { $otherEntity = null; } $sourceClass->getReflectionProperty($this->_sourceFieldName)->setValue($entity, $otherEntity); } }