. */ /** * Doctrine_Migration * * this class represents a database view * * @author Jonathan H. Wage * @package Doctrine * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @category Object Relational Mapping * @link www.phpdoctrine.com * @since 1.0 * @version $Revision: 1080 $ */ class Doctrine_Migration { public $changes = array('created_tables' => array(), 'dropped_tables' => array(), 'renamed_tables' => array(), 'added_columns' => array(), 'renamed_columns' => array(), 'changed_columns' => array(), 'removed_columns' => array(), 'added_indexes' => array(), 'removed_indexes' => array()); static public function setCurrentVersion($number) { $conn = Doctrine_Manager::connection(); try { $conn->export->createTable('migration_version', array('version' => array('type' => 'integer', 'size' => 11))); } catch(Exception $e) { } $current = self::getCurrentVersion(); if (!$current) { $conn->exec("INSERT INTO migration_version (version) VALUES ($number)"); } else { $conn->exec("UPDATE migration_version SET version = $number"); } } static public function getCurrentVersion() { $conn = Doctrine_Manager::connection(); $result = $conn->fetchColumn("SELECT version FROM migration_version"); return isset($result[0]) ? $result[0]:false; } static public function migration($from, $to) { if ($from === $to || $from === 0) { throw new Doctrine_Migration_Exception('You specified an invalid migration path. The from and to cannot be the same and from cannot be zero.'); } $direction = $from > $to ? 'down':'up'; if ($direction === 'up') { for ($i = $from + 1; $i <= $to; $i++) { self::doDirectionStep($direction, $i); } } else { for ($i = $from; $i > $to; $i--) { self::doDirectionStep($direction, $i); } } self::setCurrentVersion($to); } public static function doDirectionStep($direction, $num) { $className = 'Migration' . $num; if (class_exists($className)) { $migrate = new $className(); $migrate->migrate($direction); } else { throw new Doctrine_Migration_Exception('Could not find migration class: ' . $className); } } public static function loadMigrationClasses($directory) { $classes = get_declared_classes(); if ($directory !== null) { foreach ((array) $directory as $dir) { $it = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($dir), RecursiveIteratorIterator::LEAVES_ONLY); foreach ($it as $file) { $e = explode('.', $file->getFileName()); if (end($e) === 'php' && strpos($file->getFileName(), '.inc') === false) { require_once $file->getPathName(); } } } $classes = array_diff(get_declared_classes(), $classes); } return self::getLoadedMigrationClasses($classes); } public static function getLoadedMigrationClasses($classes = null) { if ($classes === null) { $classes = get_declared_classes(); } $parent = new ReflectionClass('Doctrine_Migration'); $loadedClasses = array(); foreach ($classes as $name) { $class = new ReflectionClass($name); while ($class->isSubclassOf($parent)) { $class = $class->getParentClass(); if ($class === false) { break; } } if ($class === false) { continue; } $loadedClasses[] = $name; } return $loadedClasses; } public function migrate($direction) { if (method_exists($this, $direction)) { $this->$direction(); $this->processChanges(); } } public function processChanges() { foreach ($this->changes as $type => $changes) { $process = new Doctrine_Migration_Process(); $funcName = 'process' . Doctrine::classify($type); $process->$funcName($changes); } } public function addChange($type, array $change = array()) { $this->changes[$type][] = $change; } public function createTable($tableName, array $fields = array(), array $options = array()) { $options = get_defined_vars(); $this->addChange('created_tables', $options); } public function dropTable($tableName) { $options = get_defined_vars(); $this->addChange('dropped_tables', $options); } public function renameTable($oldTableName, $newTableName) { $options = get_defined_vars(); $this->addChange('renamed_tables', $options); } public function addColumn($tableName, $columnName, $type, array $options = array()) { $options = get_defined_vars(); $this->addChange('added_columns', $options); } public function renameColumn($tableName, $oldColumnName, $newColumnName) { $options = get_defined_vars(); $this->addChange('renamed_columns', $options); } public function changeColumn($tableName, $columnName, $type, array $options = array()) { $options = get_defined_vars(); $this->addChange('changed_columns', $options); } public function removeColumn($tableName, $columnName) { $options = get_defined_vars(); $this->addChange('removed_columns', $options); } public function addIndex($tableName, $indexName, array $options = array()) { $options = get_defined_vars(); $this->addChange('added_indexes', $options); } public function removeIndex($tableName, $indexName) { $options = get_defined_vars(); $this->addChange('removed_indexes', $options); } }