* Backup: backing up bool columns now for all databases as 1 or 0, but understanding PostgreSQL "t" or "f" too

This commit is contained in:
Ralf Becker 2015-01-30 12:49:33 +00:00
parent 6a987a4032
commit 92ac6bb039

View File

@ -7,12 +7,14 @@
* @package api
* @subpackage db
* @author Ralf Becker <RalfBecker-AT-outdoor-training.de>
* @copyright (c) 2003-14 by Ralf Becker <RalfBecker-AT-outdoor-training.de>
* @copyright (c) 2003-15 by Ralf Becker <RalfBecker-AT-outdoor-training.de>
* @version $Id$
*/
/**
* DB independent backup and restore of EGroupware database
*
* Backing up bool columns now for all databases as 1 or 0, but understanding PostgreSQL 't' or 'f' too.
*/
class db_backup
{
@ -481,6 +483,14 @@ class db_backup
{
if ($data['type'] == 'blob') $blobs[] = $col;
}
// check if we have an old PostgreSQL backup useing 't'/'f' for bool values
// --> convert them to MySQL and our new PostgreSQL format of 1/0
$bools = array();
foreach($this->schemas[$table]['fd'] as $col => $def)
{
if ($def['type'] === 'bool') $bools[] = $col;
}
if ($table == 'egw_cal_dates') error_log(__METHOD__."() $table: bools=".array2string($bools).", schema[fd]=".array2string($this->schemas[$table]['fd']));
if (feof($f)) break;
continue;
@ -498,7 +508,7 @@ class db_backup
if ($table) // do we already reached the data part
{
$import = true;
$data = self::csv_split($line, $cols, $blobs);
$data = self::csv_split($line, $cols, $blobs, $bools);
if ($table == 'egw_async' && in_array('##last-check-run##',$data))
{
@ -644,9 +654,10 @@ class db_backup
* @param string $line line to split
* @param array $keys=null keys to use or null to use numeric ones
* @param array $blobs=array() blob columns
* @param array $bools =array() bool columns, values might be 't'/'f' for old PostgreSQL backups
* @return array
*/
public static function csv_split($line, $keys=null, $blobs=array())
public static function csv_split($line, $keys=null, $blobs=array(), $bools=array())
{
if (function_exists('str_getcsv')) // php5.3+
{
@ -685,6 +696,11 @@ class db_backup
$fields[$key] = $tmp;
}
}
// decode bool columns, they might be 't'/'f' for old PostgreSQL backups
foreach($bools as $key)
{
$fields[$key] = egw_db::from_bool($fields[$key]);
}
}
return $fields;
}
@ -715,6 +731,10 @@ class db_backup
{
$arr[$key] = base64_decode($field);
}
elseif (in_array($key, $bools))
{
$arr[$key] = egw_db::from_bool($field);
}
else
{
$arr[$key] = $field == 'NULL' ? NULL : $field;
@ -746,6 +766,9 @@ class db_backup
case 'blob':
$data = base64_encode($data);
break;
case 'bool': // we use MySQL 0, 1 in csv, not PostgreSQL 't', 'f'
$data = (int)egw_db::from_bool($data);
break;
default:
$data = '"'.str_replace(array('\\',"\n","\r",'"'),array('\\\\','\\n','\\r','\\"'),$data).'"';
break;