mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
e:
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:
parent
5fd91c426d
commit
6b35a34f91
@ -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,54 +175,57 @@ 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
|
||||||
|
$versionFields = array_merge(
|
||||||
|
array(
|
||||||
|
"RecordID" => "Int",
|
||||||
|
"Version" => "Int",
|
||||||
|
"WasPublished" => "Boolean",
|
||||||
|
"AuthorID" => "Int",
|
||||||
|
"PublisherID" => "Int"
|
||||||
|
),
|
||||||
|
(array)$fields
|
||||||
|
);
|
||||||
|
|
||||||
// Create table for all versions
|
$versionIndexes = array_merge(
|
||||||
$versionFields = array_merge(
|
array(
|
||||||
array(
|
'RecordID_Version' => '(RecordID, Version)',
|
||||||
"RecordID" => "Int",
|
'RecordID' => true,
|
||||||
"Version" => "Int",
|
'Version' => true,
|
||||||
"WasPublished" => "Boolean",
|
'AuthorID' => true,
|
||||||
"AuthorID" => "Int",
|
'PublisherID' => true,
|
||||||
"PublisherID" => "Int"
|
),
|
||||||
),
|
(array)$indexes
|
||||||
(array)$fields
|
);
|
||||||
);
|
|
||||||
|
|
||||||
$versionIndexes = array_merge(
|
|
||||||
array(
|
|
||||||
'RecordID_Version' => '(RecordID, Version)',
|
|
||||||
'RecordID' => true,
|
|
||||||
'Version' => true,
|
|
||||||
'AuthorID' => true,
|
|
||||||
'PublisherID' => true,
|
|
||||||
),
|
|
||||||
(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;
|
||||||
|
Loading…
Reference in New Issue
Block a user