FIX Remap versioned ClassNames during build process

This commit is contained in:
Robbie Averill 2017-01-12 12:15:21 +13:00
parent 747c0770e7
commit 2d1d2aea79

View File

@ -9,6 +9,7 @@ use SilverStripe\Core\Manifest\ClassLoader;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\Dev\Deprecation; use SilverStripe\Dev\Deprecation;
use SilverStripe\ORM\Versioning\Versioned;
use SilverStripe\Security\Security; use SilverStripe\Security\Security;
use SilverStripe\Security\Permission; use SilverStripe\Security\Permission;
@ -325,10 +326,19 @@ class DatabaseAdmin extends Controller
echo "<li>Correcting $badRecordCount obsolete classname values for $newClassName</li>\n"; echo "<li>Correcting $badRecordCount obsolete classname values for $newClassName</li>\n";
} }
$table = $schema->baseDataTable($baseDataClass); $table = $schema->baseDataTable($baseDataClass);
DB::prepared_query(
"UPDATE \"$table\" SET \"ClassName\" = ? WHERE \"ClassName\" = ?", $updateQuery = "UPDATE \"$table%s\" SET \"ClassName\" = ? WHERE \"ClassName\" = ?";
[ $newClassName, $oldClassName ] $updateQueries = [sprintf($updateQuery, '')];
);
// Remap versioned table ClassName values as well
if (singleton($newClassName)->has_extension(Versioned::class)) {
$updateQueries[] = sprintf($updateQuery, '_Live');
$updateQueries[] = sprintf($updateQuery, '_Versions');
}
foreach ($updateQueries as $query) {
DB::prepared_query($query, [$newClassName, $oldClassName]);
}
} }
} }
} }