git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/branches/2.3@81993 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Will Rossiter 2009-07-16 03:31:16 +00:00 committed by Sam Minnee
parent 5fd91c426d
commit 6b35a34f91

View File

@ -138,6 +138,7 @@ class Versioned extends DataObjectDecorator {
function augmentDatabase() { function augmentDatabase() {
$classTable = $this->owner->class; $classTable = $this->owner->class;
$isRootClass = ($this->owner->class == ClassInfo::baseDataClass($this->owner->class));
// Build a list of suffixes whose tables need versioning // Build a list of suffixes whose tables need versioning
$allSuffixes = array(); $allSuffixes = array();
@ -162,9 +163,6 @@ class Versioned extends DataObjectDecorator {
if(($fields = $this->owner->databaseFields())) { if(($fields = $this->owner->databaseFields())) {
$indexes = $this->owner->databaseIndexes(); $indexes = $this->owner->databaseIndexes();
if($this->owner->parentClass() == "DataObject") {
$rootTable = true;
}
if ($suffix && ($ext = $this->owner->extInstance($allSuffixes[$suffix]))) { if ($suffix && ($ext = $this->owner->extInstance($allSuffixes[$suffix]))) {
if (!$ext->isVersionedTable($table)) continue; if (!$ext->isVersionedTable($table)) continue;
$fields = $ext->fieldsInExtraTables($suffix); $fields = $ext->fieldsInExtraTables($suffix);
@ -177,22 +175,15 @@ class Versioned extends DataObjectDecorator {
// Extra tables for _Live, etc. // Extra tables for _Live, etc.
if($stage != $this->defaultStage) { if($stage != $this->defaultStage) {
DB::requireTable("{$table}_$stage", $fields, $indexes); DB::requireTable("{$table}_$stage", $fields, $indexes);
/*
if(!DB::query("SELECT * FROM {$table}_$stage")->value()) {
$fieldList = implode(", ",array_keys($fields));
DB::query("INSERT INTO `{$table}_$stage` (ID,$fieldList)
SELECT ID,$fieldList FROM `$table`");
}
*/
} }
// Version fields on each root table (including Stage) // Version fields on each root table (including Stage)
if(isset($rootTable)) { if($isRootClass) {
$stageTable = ($stage == $this->defaultStage) ? $table : "{$table}_$stage"; $stageTable = ($stage == $this->defaultStage) ? $table : "{$table}_$stage";
DB::requireField($stageTable, "Version", "int(11) not null default '0'"); DB::requireField($stageTable, "Version", "int(11) not null default '0'");
} }
} }
if($isRootClass) {
// Create table for all versions // Create table for all versions
$versionFields = array_merge( $versionFields = array_merge(
array( array(
@ -215,16 +206,26 @@ class Versioned extends DataObjectDecorator {
), ),
(array)$indexes (array)$indexes
); );
DB::requireTable("{$table}_versions", $versionFields, $versionIndexes);
/*
if(!DB::query("SELECT * FROM {$table}_versions")->value()) {
$fieldList = implode(", ",array_keys($fields));
DB::query("INSERT INTO `{$table}_versions` ($fieldList, RecordID, Version)
SELECT $fieldList, ID AS RecordID, 1 AS Version FROM `$table`");
} }
*/ else {
// Create fields for any tables of subclasses
$versionFields = array_merge(
array(
"RecordID" => "Int",
"Version" => "Int",
),
(array)$fields
);
$versionIndexes = array_merge(
array(
'RecordID_Version' => '(RecordID, Version)',
'RecordID' => true,
'Version' => true,
),
(array)$indexes
);
}
DB::requireTable("{$table}_versions", $versionFields, $versionIndexes);
} else { } else {
DB::dontRequireTable("{$table}_versions"); DB::dontRequireTable("{$table}_versions");
@ -243,14 +244,15 @@ class Versioned extends DataObjectDecorator {
$tables = array_keys($manipulation); $tables = array_keys($manipulation);
$version_table = array(); $version_table = array();
foreach($tables as $table) { foreach($tables as $table) {
$baseDataClass = ClassInfo::baseDataClass($table);
$isRootClass = ($this->owner->class == ClassInfo::baseDataClass($this->owner->class));
// Make sure that the augmented write is being applied to a table that can be versioned // Make sure that the augmented write is being applied to a table that can be versioned
if( !$this->canBeVersioned($table) ) { if( !$this->canBeVersioned($table) ) {
// Debug::message( "$table doesn't exist or has no database fields" );
unset($manipulation[$table]); unset($manipulation[$table]);
continue; continue;
} }
$id = $manipulation[$table]['id'] ? $manipulation[$table]['id'] : $manipulation[$table]['fields']['ID'];//echo 'id' .$id.' from '.$manipulation[$table]['id'].' and '.$manipulation[$table]['fields']['ID']."\n\n<br><br>"; $id = $manipulation[$table]['id'] ? $manipulation[$table]['id'] : $manipulation[$table]['fields']['ID'];
if(!$id) user_error("Couldn't find ID in " . var_export($manipulation[$table], true), E_USER_ERROR); if(!$id) user_error("Couldn't find ID in " . var_export($manipulation[$table], true), E_USER_ERROR);
$rid = isset($manipulation[$table]['RecordID']) ? $manipulation[$table]['RecordID'] : $id; $rid = isset($manipulation[$table]['RecordID']) ? $manipulation[$table]['RecordID'] : $id;
@ -264,8 +266,8 @@ class Versioned extends DataObjectDecorator {
$manipulation[$table]['fields']['Version'] = $this->migratingVersion; $manipulation[$table]['fields']['Version'] = $this->migratingVersion;
} }
// If we haven't got a version #, then we're creating a new version. Otherwise, we're just // If we haven't got a version #, then we're creating a new version.
// copying a version to another table // Otherwise, we're just copying a version to another table
if(!isset($manipulation[$table]['fields']['Version'])) { if(!isset($manipulation[$table]['fields']['Version'])) {
// Add any extra, unchanged fields to the version record. // Add any extra, unchanged fields to the version record.
@ -281,10 +283,13 @@ class Versioned extends DataObjectDecorator {
// Create a new version # // Create a new version #
if (isset($version_table[$table])) $nextVersion = $version_table[$table]; if (isset($version_table[$table])) $nextVersion = $version_table[$table];
else unset($nextVersion); else unset($nextVersion);
if($rid && !isset($nextVersion)) $nextVersion = DB::query("SELECT MAX(Version) + 1 FROM {$table}_versions WHERE RecordID = $rid")->value(); if($rid && !isset($nextVersion)) $nextVersion = DB::query("SELECT MAX(Version) + 1 FROM {$baseDataClass}_versions WHERE RecordID = $rid")->value();
$newManipulation['fields']['Version'] = $nextVersion ? $nextVersion : 1; $newManipulation['fields']['Version'] = $nextVersion ? $nextVersion : 1;
$newManipulation['fields']['AuthorID'] = Member::currentUserID() ? Member::currentUserID() : 0; if($isRootClass) {
$userID = (Member::currentUser()) ? Member::currentUser()->ID : 0;
$newManipulation['fields']['AuthorID'] = $userID;
}
$manipulation["{$table}_versions"] = $newManipulation; $manipulation["{$table}_versions"] = $newManipulation;