2008-07-20 20:13:24 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
#namespace Doctrine::ORM::Mappings;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A many-to-many mapping describes the mapping between two collections of
|
|
|
|
* entities.
|
|
|
|
*
|
|
|
|
* @since 2.0
|
|
|
|
* @todo Rename to ManyToManyMapping
|
|
|
|
*/
|
|
|
|
class Doctrine_Association_ManyToMany extends Doctrine_Association
|
2008-08-24 19:27:24 +00:00
|
|
|
{
|
2008-07-20 20:13:24 +00:00
|
|
|
/**
|
|
|
|
* The name of the association class (if an association class is used).
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2008-08-24 19:27:24 +00:00
|
|
|
private $_associationClass;
|
2008-07-20 20:13:24 +00:00
|
|
|
|
|
|
|
/** The field in the source table that corresponds to the key in the relation table */
|
2008-07-27 19:38:56 +00:00
|
|
|
protected $_sourceKeyColumns;
|
2008-07-20 20:13:24 +00:00
|
|
|
|
|
|
|
/** The field in the target table that corresponds to the key in the relation table */
|
2008-07-27 19:38:56 +00:00
|
|
|
protected $_targetKeyColumns;
|
2008-07-20 20:13:24 +00:00
|
|
|
|
|
|
|
/** The field in the intermediate table that corresponds to the key in the source table */
|
2008-07-27 19:38:56 +00:00
|
|
|
protected $_sourceRelationKeyColumns;
|
2008-07-20 20:13:24 +00:00
|
|
|
|
|
|
|
/** The field in the intermediate table that corresponds to the key in the target table */
|
2008-07-27 19:38:56 +00:00
|
|
|
protected $_targetRelationKeyColumns;
|
2008-07-20 20:13:24 +00:00
|
|
|
|
2008-08-24 19:27:24 +00:00
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
* Creates a new ManyToManyMapping.
|
|
|
|
*
|
|
|
|
* @param array $mapping The mapping info.
|
|
|
|
*/
|
|
|
|
public function __construct(array $mapping)
|
|
|
|
{
|
|
|
|
parent::__construct($mapping);
|
|
|
|
}
|
2008-07-20 20:13:24 +00:00
|
|
|
|
|
|
|
/**
|
2008-08-24 19:27:24 +00:00
|
|
|
* Validates and completes the mapping.
|
2008-07-20 20:13:24 +00:00
|
|
|
*
|
2008-08-24 19:27:24 +00:00
|
|
|
* @param array $mapping
|
|
|
|
* @override
|
2008-07-20 20:13:24 +00:00
|
|
|
*/
|
2008-08-24 19:27:24 +00:00
|
|
|
protected function _validateAndCompleteMapping(array $mapping)
|
2008-07-20 20:13:24 +00:00
|
|
|
{
|
2008-08-24 19:27:24 +00:00
|
|
|
parent::_validateAndCompleteMapping($mapping);
|
2008-07-20 20:13:24 +00:00
|
|
|
|
2008-08-24 19:27:24 +00:00
|
|
|
if ($this->isOwningSide()) {
|
|
|
|
// many-many owning MUST have a join table
|
|
|
|
if ( ! isset($mapping['joinTable'])) {
|
|
|
|
throw Doctrine_MappingException::joinTableRequired($mapping['fieldName']);
|
|
|
|
}
|
|
|
|
|
|
|
|
// optional attributes for many-many owning side
|
|
|
|
$this->_associationClass = isset($mapping['associationClass']) ?
|
|
|
|
$mapping['associationClass'] : null;
|
|
|
|
}
|
2008-07-20 20:13:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-08-24 19:27:24 +00:00
|
|
|
* Whether the mapping uses an association class for the intermediary
|
|
|
|
* table.
|
2008-07-20 20:13:24 +00:00
|
|
|
*
|
2008-08-24 19:27:24 +00:00
|
|
|
* @return boolean
|
2008-07-20 20:13:24 +00:00
|
|
|
*/
|
2008-08-24 19:27:24 +00:00
|
|
|
public function usesAssociationClass()
|
2008-07-20 20:13:24 +00:00
|
|
|
{
|
2008-08-24 19:27:24 +00:00
|
|
|
return $this->_associationClass !== null;
|
2008-07-20 20:13:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the name of the association class.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getAssociationClassName()
|
|
|
|
{
|
2008-08-24 19:27:24 +00:00
|
|
|
return $this->_associationClass;
|
2008-07-20 20:13:24 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|