101 lines
3.6 KiB
PHP
101 lines
3.6 KiB
PHP
<?php
|
|
|
|
namespace Trinity\Bundle\NewsletterBundle\Model\map;
|
|
|
|
use \RelationMap;
|
|
use \TableMap;
|
|
|
|
|
|
/**
|
|
* This class defines the structure of the 'nws_block' table.
|
|
*
|
|
*
|
|
*
|
|
* This map class is used by Propel to do runtime db structure discovery.
|
|
* For example, the createSelectSql() method checks the type of a given column used in an
|
|
* ORDER BY clause to know whether it needs to apply SQL to make the ORDER BY case-insensitive
|
|
* (i.e. if it's a text column type).
|
|
*
|
|
* @package propel.generator.vendor.trinity.src.Trinity.Bundle.NewsletterBundle.Model.map
|
|
*/
|
|
class BlockTableMap extends TableMap
|
|
{
|
|
|
|
/**
|
|
* The (dot-path) name of this class
|
|
*/
|
|
const CLASS_NAME = 'vendor.trinity.src.Trinity.Bundle.NewsletterBundle.Model.map.BlockTableMap';
|
|
|
|
/**
|
|
* Initialize the table attributes, columns and validators
|
|
* Relations are not initialized by this method since they are lazy loaded
|
|
*
|
|
* @return void
|
|
* @throws PropelException
|
|
*/
|
|
public function initialize()
|
|
{
|
|
// attributes
|
|
$this->setName('nws_block');
|
|
$this->setPhpName('Block');
|
|
$this->setClassname('Trinity\\Bundle\\NewsletterBundle\\Model\\Block');
|
|
$this->setPackage('vendor.trinity.src.Trinity.Bundle.NewsletterBundle.Model');
|
|
$this->setUseIdGenerator(true);
|
|
$this->setSingleTableInheritance(true);
|
|
// columns
|
|
$this->addPrimaryKey('id', 'Id', 'INTEGER', true, null, null);
|
|
$this->addColumn('name', 'Name', 'VARCHAR', true, 255, null);
|
|
$this->addColumn('value', 'Value', 'LONGVARCHAR', false, null, null);
|
|
$this->addColumn('class_key', 'ClassKey', 'VARCHAR', false, 255, null);
|
|
$this->addColumn('template', 'Template', 'VARCHAR', false, 255, null);
|
|
$this->addForeignKey('model_id', 'ModelId', 'INTEGER', 'nws_model', 'id', false, null, null);
|
|
$this->addColumn('created_at', 'CreatedAt', 'TIMESTAMP', false, null, null);
|
|
$this->addColumn('updated_at', 'UpdatedAt', 'TIMESTAMP', false, null, null);
|
|
$this->addColumn('version', 'Version', 'INTEGER', false, null, 0);
|
|
$this->addColumn('version_created_at', 'VersionCreatedAt', 'TIMESTAMP', false, null, null);
|
|
$this->addColumn('version_created_by', 'VersionCreatedBy', 'VARCHAR', false, 100, null);
|
|
// validators
|
|
} // initialize()
|
|
|
|
/**
|
|
* Build the RelationMap objects for this table relationships
|
|
*/
|
|
public function buildRelations()
|
|
{
|
|
$this->addRelation('Model', 'Trinity\\Bundle\\NewsletterBundle\\Model\\Model', RelationMap::MANY_TO_ONE, array('model_id' => 'id', ), 'CASCADE', null);
|
|
$this->addRelation('BlockVersion', 'Trinity\\Bundle\\NewsletterBundle\\Model\\BlockVersion', RelationMap::ONE_TO_MANY, array('id' => 'id', ), 'CASCADE', null, 'BlockVersions');
|
|
} // buildRelations()
|
|
|
|
/**
|
|
*
|
|
* Gets the list of behaviors registered for this table
|
|
*
|
|
* @return array Associative array (name => parameters) of behaviors
|
|
*/
|
|
public function getBehaviors()
|
|
{
|
|
return array(
|
|
'timestampable' => array (
|
|
'create_column' => 'created_at',
|
|
'update_column' => 'updated_at',
|
|
'disable_updated_at' => 'false',
|
|
),
|
|
'versionable' => array (
|
|
'version_column' => 'version',
|
|
'version_table' => '',
|
|
'log_created_at' => 'true',
|
|
'log_created_by' => 'true',
|
|
'log_comment' => 'false',
|
|
'version_created_at_column' => 'version_created_at',
|
|
'version_created_by_column' => 'version_created_by',
|
|
'version_comment_column' => 'version_comment',
|
|
),
|
|
'event' => array (
|
|
),
|
|
'extend' => array (
|
|
),
|
|
);
|
|
} // getBehaviors()
|
|
|
|
} // BlockTableMap
|