2011-09-04 10:08:33 +02:00
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* This software consists of voluntary contributions made by many individuals
|
2012-05-26 14:37:00 +02:00
|
|
|
* and is licensed under the MIT license. For more information, see
|
2011-09-04 10:08:33 +02:00
|
|
|
* <http://www.doctrine-project.org>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Doctrine\ORM\Mapping\Builder;
|
|
|
|
|
2011-12-09 00:04:47 -05:00
|
|
|
use Doctrine\ORM\Mapping\ClassMetadata,
|
|
|
|
Doctrine\ORM\Mapping\ClassMetadataInfo;
|
2011-09-04 10:08:33 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Builder Object for ClassMetadata
|
|
|
|
*
|
|
|
|
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
|
|
|
* @link www.doctrine-project.com
|
2011-09-04 14:13:20 +02:00
|
|
|
* @since 2.2
|
2011-09-04 10:08:33 +02:00
|
|
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
2011-12-09 00:04:47 -05:00
|
|
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
2011-09-04 10:08:33 +02:00
|
|
|
*/
|
|
|
|
class ClassMetadataBuilder
|
|
|
|
{
|
|
|
|
/**
|
2011-12-09 00:04:47 -05:00
|
|
|
* @var \Doctrine\ORM\Mapping\ClassMetadataInfo
|
2011-09-04 10:08:33 +02:00
|
|
|
*/
|
|
|
|
private $cm;
|
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
/**
|
2011-12-09 00:04:47 -05:00
|
|
|
* @param \Doctrine\ORM\Mapping\ClassMetadataInfo $cm
|
2011-09-04 14:13:20 +02:00
|
|
|
*/
|
2011-12-09 00:04:47 -05:00
|
|
|
public function __construct(ClassMetadataInfo $cm)
|
2011-09-04 10:08:33 +02:00
|
|
|
{
|
|
|
|
$this->cm = $cm;
|
|
|
|
}
|
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
/**
|
|
|
|
* @return ClassMetadata
|
|
|
|
*/
|
|
|
|
public function getClassMetadata()
|
|
|
|
{
|
|
|
|
return $this->cm;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Mark the class as mapped superclass.
|
|
|
|
*
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
2011-09-04 10:08:33 +02:00
|
|
|
public function setMappedSuperClass()
|
|
|
|
{
|
|
|
|
$this->cm->isMappedSuperclass = true;
|
2011-12-19 22:56:19 +01:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
2011-09-04 10:08:33 +02:00
|
|
|
}
|
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
/**
|
|
|
|
* Set custom Repository class name
|
|
|
|
*
|
|
|
|
* @param string $repositoryClassName
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
2011-09-04 10:08:33 +02:00
|
|
|
public function setCustomRepositoryClass($repositoryClassName)
|
|
|
|
{
|
|
|
|
$this->cm->setCustomRepositoryClass($repositoryClassName);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
2011-09-04 10:08:33 +02:00
|
|
|
}
|
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
/**
|
|
|
|
* Mark class read only
|
|
|
|
*
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
2011-09-04 10:08:33 +02:00
|
|
|
public function setReadOnly()
|
|
|
|
{
|
|
|
|
$this->cm->markReadOnly();
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
2011-09-04 10:08:33 +02:00
|
|
|
}
|
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
/**
|
|
|
|
* Set the table name
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
2011-09-04 10:08:33 +02:00
|
|
|
public function setTable($name)
|
|
|
|
{
|
|
|
|
$this->cm->setPrimaryTable(array('name' => $name));
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
2011-09-04 10:08:33 +02:00
|
|
|
}
|
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
/**
|
|
|
|
* Add Index
|
|
|
|
*
|
|
|
|
* @param array $columns
|
|
|
|
* @param string $name
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
2011-09-04 10:08:33 +02:00
|
|
|
public function addIndex(array $columns, $name)
|
|
|
|
{
|
|
|
|
if (!isset($this->cm->table['indexes'])) {
|
|
|
|
$this->cm->table['indexes'] = array();
|
|
|
|
}
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 10:08:33 +02:00
|
|
|
$this->cm->table['indexes'][$name] = array('columns' => $columns);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
2011-09-04 10:08:33 +02:00
|
|
|
}
|
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
/**
|
|
|
|
* Add Unique Constraint
|
|
|
|
*
|
|
|
|
* @param array $columns
|
|
|
|
* @param string $name
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
2011-09-04 10:08:33 +02:00
|
|
|
public function addUniqueConstraint(array $columns, $name)
|
|
|
|
{
|
2011-12-09 00:04:47 -05:00
|
|
|
if ( ! isset($this->cm->table['uniqueConstraints'])) {
|
2011-09-04 10:08:33 +02:00
|
|
|
$this->cm->table['uniqueConstraints'] = array();
|
|
|
|
}
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 10:08:33 +02:00
|
|
|
$this->cm->table['uniqueConstraints'][$name] = array('columns' => $columns);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add named query
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $dqlQuery
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addNamedQuery($name, $dqlQuery)
|
|
|
|
{
|
|
|
|
$this->cm->addNamedQuery(array(
|
|
|
|
'name' => $name,
|
|
|
|
'query' => $dqlQuery,
|
|
|
|
));
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set class as root of a joined table inheritance hierachy.
|
|
|
|
*
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function setJoinedTableInheritance()
|
|
|
|
{
|
|
|
|
$this->cm->setInheritanceType(ClassMetadata::INHERITANCE_TYPE_JOINED);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set class as root of a single table inheritance hierachy.
|
|
|
|
*
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function setSingleTableInheritance()
|
|
|
|
{
|
|
|
|
$this->cm->setInheritanceType(ClassMetadata::INHERITANCE_TYPE_SINGLE_TABLE);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the discriminator column details.
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $type
|
|
|
|
*/
|
|
|
|
public function setDiscriminatorColumn($name, $type = 'string', $length = 255)
|
|
|
|
{
|
|
|
|
$this->cm->setDiscriminatorColumn(array(
|
|
|
|
'name' => $name,
|
|
|
|
'type' => $type,
|
|
|
|
'length' => $length,
|
|
|
|
));
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a subclass to this inheritance hierachy.
|
2011-12-09 00:04:47 -05:00
|
|
|
*
|
2011-09-04 14:13:20 +02:00
|
|
|
* @param string $name
|
|
|
|
* @param string $class
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addDiscriminatorMapClass($name, $class)
|
|
|
|
{
|
|
|
|
$this->cm->addDiscriminatorMapClass($name, $class);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set deferred explicit change tracking policy.
|
|
|
|
*
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function setChangeTrackingPolicyDeferredExplicit()
|
|
|
|
{
|
|
|
|
$this->cm->setChangeTrackingPolicy(ClassMetadata::CHANGETRACKING_DEFERRED_EXPLICIT);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set notify change tracking policy.
|
|
|
|
*
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function setChangeTrackingPolicyNotify()
|
|
|
|
{
|
|
|
|
$this->cm->setChangeTrackingPolicy(ClassMetadata::CHANGETRACKING_NOTIFY);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add lifecycle event
|
2011-12-09 00:04:47 -05:00
|
|
|
*
|
2011-09-04 14:13:20 +02:00
|
|
|
* @param string $methodName
|
|
|
|
* @param string $event
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addLifecycleEvent($methodName, $event)
|
|
|
|
{
|
|
|
|
$this->cm->addLifecycleCallback($methodName, $event);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add Field
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $type
|
|
|
|
* @param array $mapping
|
|
|
|
*/
|
|
|
|
public function addField($name, $type, array $mapping = array())
|
|
|
|
{
|
|
|
|
$mapping['fieldName'] = $name;
|
|
|
|
$mapping['type'] = $type;
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
$this->cm->mapField($mapping);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a field builder.
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $type
|
|
|
|
* @return FieldBuilder
|
|
|
|
*/
|
|
|
|
public function createField($name, $type)
|
|
|
|
{
|
2011-12-09 00:04:47 -05:00
|
|
|
return new FieldBuilder(
|
|
|
|
$this,
|
|
|
|
array(
|
|
|
|
'fieldName' => $name,
|
|
|
|
'type' => $type
|
|
|
|
)
|
|
|
|
);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a simple many to one association, optionally with the inversed by field.
|
2011-12-09 00:04:47 -05:00
|
|
|
*
|
2011-09-04 14:13:20 +02:00
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @param string|null $inversedBy
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addManyToOne($name, $targetEntity, $inversedBy = null)
|
|
|
|
{
|
|
|
|
$builder = $this->createManyToOne($name, $targetEntity);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
if ($inversedBy) {
|
2011-12-17 12:39:44 +01:00
|
|
|
$builder->inversedBy($inversedBy);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $builder->build();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a ManyToOne Assocation Builder.
|
|
|
|
*
|
|
|
|
* Note: This method does not add the association, you have to call build() on the AssociationBuilder.
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @return AssociationBuilder
|
|
|
|
*/
|
|
|
|
public function createManyToOne($name, $targetEntity)
|
|
|
|
{
|
2011-12-09 00:04:47 -05:00
|
|
|
return new AssociationBuilder(
|
|
|
|
$this,
|
|
|
|
array(
|
|
|
|
'fieldName' => $name,
|
|
|
|
'targetEntity' => $targetEntity
|
|
|
|
),
|
|
|
|
ClassMetadata::MANY_TO_ONE
|
|
|
|
);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create OneToOne Assocation Builder
|
2011-12-09 00:04:47 -05:00
|
|
|
*
|
2011-09-04 14:13:20 +02:00
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @return AssociationBuilder
|
|
|
|
*/
|
|
|
|
public function createOneToOne($name, $targetEntity)
|
|
|
|
{
|
2011-12-09 00:04:47 -05:00
|
|
|
return new AssociationBuilder(
|
|
|
|
$this,
|
|
|
|
array(
|
|
|
|
'fieldName' => $name,
|
|
|
|
'targetEntity' => $targetEntity
|
|
|
|
),
|
|
|
|
ClassMetadata::ONE_TO_ONE
|
|
|
|
);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add simple inverse one-to-one assocation.
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @param string $mappedBy
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addInverseOneToOne($name, $targetEntity, $mappedBy)
|
|
|
|
{
|
|
|
|
$builder = $this->createOneToOne($name, $targetEntity);
|
2011-12-17 12:39:44 +01:00
|
|
|
$builder->mappedBy($mappedBy);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $builder->build();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add simple owning one-to-one assocation.
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @param string $inversedBy
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addOwningOneToOne($name, $targetEntity, $inversedBy = null)
|
|
|
|
{
|
|
|
|
$builder = $this->createOneToOne($name, $targetEntity);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
if ($inversedBy) {
|
2011-12-17 12:39:44 +01:00
|
|
|
$builder->inversedBy($inversedBy);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $builder->build();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create ManyToMany Assocation Builder
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @return ManyToManyAssociationBuilder
|
|
|
|
*/
|
|
|
|
public function createManyToMany($name, $targetEntity)
|
|
|
|
{
|
2011-12-09 00:04:47 -05:00
|
|
|
return new ManyToManyAssociationBuilder(
|
|
|
|
$this,
|
|
|
|
array(
|
|
|
|
'fieldName' => $name,
|
|
|
|
'targetEntity' => $targetEntity
|
|
|
|
),
|
|
|
|
ClassMetadata::MANY_TO_MANY
|
|
|
|
);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a simple owning many to many assocation.
|
2011-12-09 00:04:47 -05:00
|
|
|
*
|
2011-09-04 14:13:20 +02:00
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @param string|null $inversedBy
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addOwningManyToMany($name, $targetEntity, $inversedBy = null)
|
|
|
|
{
|
|
|
|
$builder = $this->createManyToMany($name, $targetEntity);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
if ($inversedBy) {
|
2011-12-17 12:39:44 +01:00
|
|
|
$builder->inversedBy($inversedBy);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $builder->build();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a simple inverse many to many assocation.
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @param string $mappedBy
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addInverseManyToMany($name, $targetEntity, $mappedBy)
|
|
|
|
{
|
|
|
|
$builder = $this->createManyToMany($name, $targetEntity);
|
2011-12-17 12:39:44 +01:00
|
|
|
$builder->mappedBy($mappedBy);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $builder->build();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a one to many assocation builder
|
2011-12-09 00:04:47 -05:00
|
|
|
*
|
2011-09-04 14:13:20 +02:00
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @return OneToManyAssociationBuilder
|
|
|
|
*/
|
|
|
|
public function createOneToMany($name, $targetEntity)
|
|
|
|
{
|
2011-12-09 00:04:47 -05:00
|
|
|
return new OneToManyAssociationBuilder(
|
|
|
|
$this,
|
|
|
|
array(
|
|
|
|
'fieldName' => $name,
|
|
|
|
'targetEntity' => $targetEntity
|
|
|
|
),
|
|
|
|
ClassMetadata::ONE_TO_MANY
|
|
|
|
);
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add simple OneToMany assocation.
|
2011-12-09 00:04:47 -05:00
|
|
|
*
|
2011-09-04 14:13:20 +02:00
|
|
|
* @param string $name
|
|
|
|
* @param string $targetEntity
|
|
|
|
* @param string $mappedBy
|
|
|
|
* @return ClassMetadataBuilder
|
|
|
|
*/
|
|
|
|
public function addOneToMany($name, $targetEntity, $mappedBy)
|
|
|
|
{
|
|
|
|
$builder = $this->createOneToMany($name, $targetEntity);
|
2011-12-17 12:39:44 +01:00
|
|
|
$builder->mappedBy($mappedBy);
|
2011-12-09 00:04:47 -05:00
|
|
|
|
2011-09-04 14:13:20 +02:00
|
|
|
return $builder->build();
|
2011-09-04 10:08:33 +02:00
|
|
|
}
|
2011-09-04 14:13:20 +02:00
|
|
|
}
|