|
|
|
|
@ -338,7 +338,6 @@ class OC_DB { |
|
|
|
|
* @param $file file to read structure from |
|
|
|
|
*/ |
|
|
|
|
public static function updateDbFromStructure($file){ |
|
|
|
|
$CONFIG_DBNAME = OC_Config::getValue( "dbname", "owncloud" ); |
|
|
|
|
$CONFIG_DBTABLEPREFIX = OC_Config::getValue( "dbtableprefix", "oc_" ); |
|
|
|
|
$CONFIG_DBTYPE = OC_Config::getValue( "dbtype", "sqlite" ); |
|
|
|
|
|
|
|
|
|
@ -347,17 +346,17 @@ class OC_DB { |
|
|
|
|
// read file |
|
|
|
|
$content = file_get_contents( $file ); |
|
|
|
|
|
|
|
|
|
$previousSchema = self::$schema->getDefinitionFromDatabase(); |
|
|
|
|
|
|
|
|
|
// Make changes and save them to a temporary file |
|
|
|
|
$file2 = tempnam( get_temp_dir(), 'oc_db_scheme_' ); |
|
|
|
|
$content = str_replace( '*dbname*', $CONFIG_DBNAME, $content ); |
|
|
|
|
$content = str_replace( '*dbname*', $previousSchema['name'], $content ); |
|
|
|
|
$content = str_replace( '*dbprefix*', $CONFIG_DBTABLEPREFIX, $content ); |
|
|
|
|
if( $CONFIG_DBTYPE == 'pgsql' ){ //mysql support it too but sqlite doesn't |
|
|
|
|
$content = str_replace( '<default>0000-00-00 00:00:00</default>', '<default>CURRENT_TIMESTAMP</default>', $content ); |
|
|
|
|
} |
|
|
|
|
file_put_contents( $file2, $content ); |
|
|
|
|
$previousSchema = self::$schema->getDefinitionFromDatabase(); |
|
|
|
|
$op = $schema->updateDatabase($file2, $previousSchema, array(), false); |
|
|
|
|
|
|
|
|
|
$op = self::$schema->updateDatabase($file2, $previousSchema, array(), false); |
|
|
|
|
if (PEAR::isError($op)) { |
|
|
|
|
$error = $op->getMessage(); |
|
|
|
|
OC_Log::write('core','Failed to update database structure ('.$error.')',OC_Log::FATAL); |
|
|
|
|
|