fixed a handfull of bugs that broke setup/update from 1.0 to 1.2

This commit is contained in:
Carsten Wolff 2006-01-06 16:21:51 +00:00
parent e72bb9b10a
commit 99cb0bd567
6 changed files with 112 additions and 50 deletions

View File

@ -1166,7 +1166,7 @@
function calendar_upgrade1_0_0_005() function calendar_upgrade1_0_0_005()
{ {
// change prefix of all calendar tables to egw_ // change prefix of all calendar tables to egw_
foreach(array('cal','cal_user','cal_repeats','cal_extra','cal_holidays') as $name) foreach(array('cal_user','cal_repeats','cal_extra','cal_holidays','cal') as $name)
{ {
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_'.$name,'egw_'.$name); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_'.$name,'egw_'.$name);
} }

View File

@ -402,7 +402,7 @@
'precision' => '2', 'precision' => '2',
'default' => '1' 'default' => '1'
)); ));
$GLOBALS['phpgw_setup']->oProc->query("UPDATE phpgw_infolog SET info_priority=(CASE WHEN info_pri='urgent' THEN 3 WHEN info_pre='high' THEN 2 WHEN info_pri='low' THEN 0 ELSE 1 END)",__LINE__,__FILE__); $GLOBALS['phpgw_setup']->oProc->query("UPDATE phpgw_infolog SET info_priority=(CASE WHEN info_pri='urgent' THEN 3 WHEN info_pri='high' THEN 2 WHEN info_pri='low' THEN 0 ELSE 1 END)",__LINE__,__FILE__);
$GLOBALS['phpgw_setup']->oProc->DropColumn('phpgw_infolog',array( $GLOBALS['phpgw_setup']->oProc->DropColumn('phpgw_infolog',array(
'fd' => array( 'fd' => array(

View File

@ -894,7 +894,8 @@
*/ */
function table_names() function table_names()
{ {
if (!$this->Link_ID && !$this->connect()) if (!$this->Link_ID) $this->connect();
if (!$this->Link_ID)
{ {
return False; return False;
} }
@ -1284,13 +1285,15 @@
* @param int $line line-number to pass to query * @param int $line line-number to pass to query
* @param string $file file-name to pass to query * @param string $file file-name to pass to query
* @param string/boolean $app string with name of app or False to use the current-app * @param string/boolean $app string with name of app or False to use the current-app
* @param bool $use_prepared_statement use a prepared statement
* @param array/bool $table_def use this table definition. If False, the table definition will be read from tables_baseline
* @return ADORecordSet or false, if the query fails * @return ADORecordSet or false, if the query fails
*/ */
function insert($table,$data,$where,$line,$file,$app=False,$use_prepared_statement=false) function insert($table,$data,$where,$line,$file,$app=False,$use_prepared_statement=false,$table_def=False)
{ {
if ($this->Debug) echo "<p>db::insert('$table',".print_r($data,True).",".print_r($where,True).",$line,$file,'$app')</p>\n"; if ($this->Debug) echo "<p>db::insert('$table',".print_r($data,True).",".print_r($where,True).",$line,$file,'$app')</p>\n";
$table_def = $this->get_table_definitions($app,$table); if (!$table_def) $table_def = $this->get_table_definitions($app,$table);
$sql_append = ''; $sql_append = '';
$cmd = 'INSERT'; $cmd = 'INSERT';
@ -1368,12 +1371,14 @@
* @param int $line line-number to pass to query * @param int $line line-number to pass to query
* @param string $file file-name to pass to query * @param string $file file-name to pass to query
* @param string/boolean $app string with name of app or False to use the current-app * @param string/boolean $app string with name of app or False to use the current-app
* @param bool $use_prepared_statement use a prepared statement
* @param array/bool $table_def use this table definition. If False, the table definition will be read from tables_baseline
* @return ADORecordSet or false, if the query fails * @return ADORecordSet or false, if the query fails
*/ */
function update($table,$data,$where,$line,$file,$app=False,$use_prepared_statement=false) function update($table,$data,$where,$line,$file,$app=False,$use_prepared_statement=false,$table_def=False)
{ {
if ($this->Debug) echo "<p>db::update('$table',".print_r($data,true).','.print_r($where,true).",$line,$file,'$app')</p>\n"; if ($this->Debug) echo "<p>db::update('$table',".print_r($data,true).','.print_r($where,true).",$line,$file,'$app')</p>\n";
$table_def = $this->get_table_definitions($app,$table); if (!$table_def) $table_def = $this->get_table_definitions($app,$table);
$blobs2update = array(); $blobs2update = array();
// SapDB/MaxDB cant update LONG columns / blob's: if a blob-column is included in the update we remember it in $blobs2update // SapDB/MaxDB cant update LONG columns / blob's: if a blob-column is included in the update we remember it in $blobs2update
@ -1451,11 +1456,12 @@
* @param int $line line-number to pass to query * @param int $line line-number to pass to query
* @param string $file file-name to pass to query * @param string $file file-name to pass to query
* @param string/boolean $app string with name of app or False to use the current-app * @param string/boolean $app string with name of app or False to use the current-app
* @param array/bool $table_def use this table definition. If False, the table definition will be read from tables_baseline
* @return ADORecordSet or false, if the query fails * @return ADORecordSet or false, if the query fails
*/ */
function delete($table,$where,$line,$file,$app=False) function delete($table,$where,$line,$file,$app=False,$table_def=False)
{ {
$table_def = $this->get_table_definitions($app,$table); if (!$table_def) $table_def = $this->get_table_definitions($app,$table);
$sql = "DELETE FROM $table WHERE ". $sql = "DELETE FROM $table WHERE ".
$this->column_data_implode(' AND ',$where,True,False,$table_def['fd']); $this->column_data_implode(' AND ',$where,True,False,$table_def['fd']);
@ -1474,11 +1480,12 @@
* array: column-name / value pairs: the value gets quoted according to the type of the column and prefixed * array: column-name / value pairs: the value gets quoted according to the type of the column and prefixed
* with column-name=, multiple pairs are AND'ed together, see db::column_data_implode * with column-name=, multiple pairs are AND'ed together, see db::column_data_implode
* bool: If False or is_null($arg): the next 2 (!) arguments gets ignored * bool: If False or is_null($arg): the next 2 (!) arguments gets ignored
* @param array/bool $table_def use this table definition. If False, the table definition will be read from tables_baseline
* @return string the expression generated from the arguments * @return string the expression generated from the arguments
*/ */
function expression($table,$args) function expression($table,$args,$table_def=False)
{ {
$table_def = $this->get_table_definitions('',$table); if (!$table_def) $table_def = $this->get_table_definitions('',$table);
$sql = ''; $sql = '';
$ignore_next = 0; $ignore_next = 0;
foreach(func_get_args() as $n => $arg) foreach(func_get_args() as $n => $arg)
@ -1525,13 +1532,14 @@
* @param int $num_rows number of rows to return if offset set, default 0 = use default in user prefs * @param int $num_rows number of rows to return if offset set, default 0 = use default in user prefs
* @param string $join=null sql to do a join, added as is after the table-name, eg. ", table2 WHERE x=y" or * @param string $join=null sql to do a join, added as is after the table-name, eg. ", table2 WHERE x=y" or
* "LEFT JOIN table2 ON (x=y)", Note: there's no quoting done on $join! * "LEFT JOIN table2 ON (x=y)", Note: there's no quoting done on $join!
* @param array/bool $table_def use this table definition. If False, the table definition will be read from tables_baseline
* @return ADORecordSet or false, if the query fails * @return ADORecordSet or false, if the query fails
*/ */
function select($table,$cols,$where,$line,$file,$offset=False,$append='',$app=False,$num_rows=0,$join='') function select($table,$cols,$where,$line,$file,$offset=False,$append='',$app=False,$num_rows=0,$join='',$table_def=False)
{ {
if ($this->Debug) echo "<p>db::select('$table',".print_r($cols,True).",".print_r($where,True).",$line,$file,$offset,'$app')</p>\n"; if ($this->Debug) echo "<p>db::select('$table',".print_r($cols,True).",".print_r($where,True).",$line,$file,$offset,'$app')</p>\n";
$table_def = $this->get_table_definitions($app,$table); if (!$table_def) $table_def = $this->get_table_definitions($app,$table);
if (is_array($cols)) if (is_array($cols))
{ {
$cols = implode(',',$cols); $cols = implode(',',$cols);

View File

@ -70,6 +70,10 @@
* @var array $capabilities reference to the array of the db-class * @var array $capabilities reference to the array of the db-class
*/ */
var $capabilities; var $capabilities;
/**
* @var int $pgsql_old_seq preserve value of old sequences in PostgreSQL
*/
var $pgsql_old_seq;
/** /**
* Constructor of schema-processor * Constructor of schema-processor
@ -115,9 +119,10 @@
* *
* @param string $sTableName * @param string $sTableName
* @param array $aTableDef * @param array $aTableDef
* @param bool $preserveSequence
* @return int 2: no error, 1: errors, but continued, 0: errors aborted * @return int 2: no error, 1: errors, but continued, 0: errors aborted
*/ */
function CreateTable($sTableName, $aTableDef) function CreateTable($sTableName, $aTableDef, $preserveSequence=False)
{ {
if ($this->debug) if ($this->debug)
{ {
@ -192,6 +197,16 @@
return $retVal; return $retVal;
} }
} }
// preserve last value of an old sequence
if ($this->sType == 'pgsql' && $preserveSequence && $this->pgsql_old_seq)
{
if ($seq = $this->_PostgresHasOldSequence($sTableName))
{
$this->pgsql_old_seq = $this->pgsql_old_seq + 1;
$this->m_odb->query("ALTER SEQUENCE $seq RESTART WITH " . $this->pgsql_old_seq,__LINE__,__FILE__);
}
$this->pgsql_old_seq = 0;
}
return $retVal; return $retVal;
} }
@ -278,11 +293,11 @@
{ {
$table_def = $this->GetTableDefinition($sOldTableName); $table_def = $this->GetTableDefinition($sOldTableName);
if ($this->_PostgresHasOldSequence($sOldTableName) || count($table_def['pk']) || if ($this->_PostgresHasOldSequence($sOldTableName,True) || count($table_def['pk']) ||
count($table_def['ix']) || count($table_def['uc'])) count($table_def['ix']) || count($table_def['uc']))
{ {
if ($this->adodb->BeginTrans() && if ($this->adodb->BeginTrans() &&
$this->CreateTable($sNewTableName,$table_def) && $this->CreateTable($sNewTableName,$table_def,True) &&
$this->m_odb->query("INSERT INTO $sNewTableName SELECT * FROM $sOldTableName",__LINE__,__FILE__) && $this->m_odb->query("INSERT INTO $sNewTableName SELECT * FROM $sOldTableName",__LINE__,__FILE__) &&
$this->DropTable($sOldTableName)) $this->DropTable($sOldTableName))
{ {
@ -302,17 +317,24 @@
* Check if we have an old, not automaticaly droped sequence * Check if we have an old, not automaticaly droped sequence
* *
* @param string $sTableName * @param string $sTableName
* @param boolean/string sequence-name or false * @param bool $preserveValue
* @return boolean/string sequence-name or false
*/ */
function _PostgresHasOldSequence($sTableName) function _PostgresHasOldSequence($sTableName,$preserveValue=False)
{ {
if ($this->sType != 'pgsql') return false; if ($this->sType != 'pgsql') return false;
$seq = $this->adodb->GetOne("SELECT d.adsrc FROM pg_attribute a, pg_class c, pg_attrdef d WHERE c.relname='$sTableName' AND c.oid=d.adrelid AND d.adsrc LIKE '%seq_$sTableName%' AND a.attrelid=c.oid AND d.adnum=a.attnum"); $seq = $this->adodb->GetOne("SELECT d.adsrc FROM pg_attribute a, pg_class c, pg_attrdef d WHERE c.relname='$sTableName' AND c.oid=d.adrelid AND d.adsrc LIKE '%seq_$sTableName\'::text)' AND a.attrelid=c.oid AND d.adnum=a.attnum");
$seq2 = $this->adodb->GetOne("SELECT d.adsrc FROM pg_attribute a, pg_class c, pg_attrdef d WHERE c.relname='$sTableName' AND c.oid=d.adrelid AND d.adsrc LIKE '%$sTableName%_seq\'::text)' AND a.attrelid=c.oid AND d.adnum=a.attnum");
if ($seq && preg_match('/^nextval\(\'(.*)\'/',$seq,$matches)) if ($seq && preg_match('/^nextval\(\'(.*)\'/',$seq,$matches))
{ {
if ($preserveValue) $this->pgsql_old_seq = $this->adodb->GetOne("SELECT last_value FROM " . $matches[1]);
return $matches[1];
}
if ($seq2 && preg_match('/^nextval\(\'public\.(.*)\'/',$seq2,$matches))
{
if ($preserveValue) $this->pgsql_old_seq = $this->adodb->GetOne("SELECT last_value FROM " . $matches[1]);
return $matches[1]; return $matches[1];
} }
return false; return false;
@ -322,14 +344,20 @@
* Check if we have an old, not automaticaly droped sequence and drop it * Check if we have an old, not automaticaly droped sequence and drop it
* *
* @param $sTableName * @param $sTableName
* @param bool $preserveValue
*/ */
function _PostgresTestDropOldSequence($sTableName) function _PostgresTestDropOldSequence($sTableName,$preserveValue=False)
{ {
$this->pgsql_old_seq = 0;
if ($this->sType == 'pgsql' && ($seq = $this->_PostgresHasOldSequence($sTableName))) if ($this->sType == 'pgsql' && ($seq = $this->_PostgresHasOldSequence($sTableName)))
{ {
// only drop sequence, if there is no dependency on it
if (!$this->adodb->GetOne("SELECT relname FROM pg_class JOIN pg_depend ON pg_class.relfilenode=pg_depend.objid WHERE relname='$seq' AND relkind='S' AND deptype='i'"))
{
$this->query('DROP SEQUENCE '.$seq,__LINE__,__FILE__); $this->query('DROP SEQUENCE '.$seq,__LINE__,__FILE__);
} }
} }
}
/** /**
* Changes one (exiting) column in a table * Changes one (exiting) column in a table
@ -365,6 +393,7 @@
function RenameColumn($sTableName, $sOldColumnName, $sNewColumnName, $bCopyData=True) function RenameColumn($sTableName, $sOldColumnName, $sNewColumnName, $bCopyData=True)
{ {
$table_def = $this->GetTableDefinition($sTableName); $table_def = $this->GetTableDefinition($sTableName);
$old_def = array();
if (isset($table_def['fd'][$sOldColumnName])) if (isset($table_def['fd'][$sOldColumnName]))
{ {
@ -374,7 +403,7 @@
{ {
foreach($table_def['fd'] as $col => $def) foreach($table_def['fd'] as $col => $def)
{ {
if (strtolower($col) == strtolower($OldColumnName)) if (strtolower($col) == strtolower($sOldColumnName))
{ {
$old_def = $def; $old_def = $def;
break; break;
@ -1034,6 +1063,7 @@
'F' => 'float', 'F' => 'float',
'N' => 'decimal', 'N' => 'decimal',
'R' => 'auto', 'R' => 'auto',
'L' => 'bool',
); );
$definition['fd'][$name]['type'] = $ado_type2egw[$type]; $definition['fd'][$name]['type'] = $ado_type2egw[$type];

View File

@ -93,6 +93,10 @@
{ {
// removing the ACL entries of deleted accounts // removing the ACL entries of deleted accounts
$GLOBALS['egw_setup']->setup_account_object(); $GLOBALS['egw_setup']->setup_account_object();
if ($GLOBALS['phpgw']->accounts->table)
{
$GLOBALS['phpgw']->accounts->table = $GLOBALS['egw_setup']->accounts_table;
}
if (($all_accounts = $GLOBALS['phpgw']->accounts->search(array('type'=>'both')))) if (($all_accounts = $GLOBALS['phpgw']->accounts->search(array('type'=>'both'))))
{ {
$all_accounts = array_keys($all_accounts); $all_accounts = array_keys($all_accounts);
@ -390,7 +394,7 @@
$GLOBALS['egw_setup']->oProc->AddColumn('phpgw_vfs2_files', 'modified', array('type' => 'timestamp', 'nullable' => true)); $GLOBALS['egw_setup']->oProc->AddColumn('phpgw_vfs2_files', 'modified', array('type' => 'timestamp', 'nullable' => true));
//Updating existing values //Updating existing values
$sql = "SELECT max(modified) as mod, file_id, modifiedby_id from phpgw_vfs2_versioning group by file_id"; $sql = "SELECT max(modified) as mod, file_id, min(modifiedby_id) from phpgw_vfs2_versioning group by file_id";
$GLOBALS['egw_setup']->oProc->m_odb->query($sql,__LINE__,__FILE__); $GLOBALS['egw_setup']->oProc->m_odb->query($sql,__LINE__,__FILE__);
@ -492,10 +496,10 @@
'app_version' => $home_version, 'app_version' => $home_version,
),array( ),array(
'app_name' => 'home', 'app_name' => 'home',
),__LINE__,__FILE__); ),__LINE__,__FILE__,False,False,$GLOBALS['egw_setup']->oProc->GetTableDefinition($GLOBALS['egw_setup']->applications_table));
// give all users and groups with preferences rights, rights for the home app. // give all users and groups with preferences rights, rights for the home app.
$GLOBALS['egw_setup']->db->select('phpgw_acl','acl_account',array( $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->acl_table,'acl_account',array(
'acl_appname' => 'preferences', 'acl_appname' => 'preferences',
'acl_location' => 'run', 'acl_location' => 'run',
'acl_rights' => 1, 'acl_rights' => 1,
@ -507,13 +511,13 @@
} }
foreach($accounts_with_preference_rights as $account) foreach($accounts_with_preference_rights as $account)
{ {
$GLOBALS['egw_setup']->db->insert('phpgw_acl',array( $GLOBALS['egw_setup']->db->insert($GLOBALS['egw_setup']->acl_table,array(
'acl_rights' => 1, 'acl_rights' => 1,
),array( ),array(
'acl_appname' => 'home', 'acl_appname' => 'home',
'acl_location' => 'run', 'acl_location' => 'run',
'acl_account' => $account, 'acl_account' => $account,
),__LINE__,__FILE__); ),__LINE__,__FILE__,False,False,$GLOBALS['egw_setup']->oProc->GetTableDefinition($GLOBALS['egw_setup']->acl_table));
} }
} }
$GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.010'; $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.010';
@ -584,9 +588,13 @@
function phpgwapi_upgrade1_0_1_012() function phpgwapi_upgrade1_0_1_012()
{ {
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_accounts','egw_accounts'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_accounts','egw_accounts');
$GLOBALS['egw_setup']->accounts_table = 'egw_accounts'; $GLOBALS['egw_setup']->set_table_names(True);
if ($GLOBALS['phpgw']->accounts->table)
{
$GLOBALS['phpgw']->accounts->table = $GLOBALS['egw_setup']->accounts_table;
}
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_acl','egw_acl'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_acl','egw_acl');
$GLOBALS['egw_setup']->acl_table = 'egw_acl'; $GLOBALS['egw_setup']->set_table_names(True);
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_log','egw_log'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_log','egw_log');
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_log_msg','egw_log_msg'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_log_msg','egw_log_msg');
@ -598,9 +606,9 @@
function phpgwapi_upgrade1_0_1_013() function phpgwapi_upgrade1_0_1_013()
{ {
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_config','egw_config'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_config','egw_config');
$GLOBALS['egw_setup']->config_table = 'egw_config'; $GLOBALS['egw_setup']->set_table_names(True);
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_applications','egw_applications'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_applications','egw_applications');
$GLOBALS['egw_setup']->applications_table = 'egw_applications'; $GLOBALS['egw_setup']->set_table_names(True);
$GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.014'; $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.014';
return $GLOBALS['setup_info']['phpgwapi']['currentver']; return $GLOBALS['setup_info']['phpgwapi']['currentver'];
@ -611,7 +619,9 @@
{ {
// index was to big for mysql with charset utf8 (max 1000byte = 333 utf8 chars) // index was to big for mysql with charset utf8 (max 1000byte = 333 utf8 chars)
// before we can shorten the message_id, we have to make sure there are no identical message_id > 128 chars // before we can shorten the message_id, we have to make sure there are no identical message_id > 128 chars
// and we have to truncate the message_id explicitly, postgresql f.e. will not do it for us, but bail out instead
$to_delete = array(); $to_delete = array();
$to_truncate = array();
$GLOBALS['egw_setup']->db->select('phpgw_lang','app_name,lang,message_id','LENGTH(message_id) > 128',__LINE__,__FILE__, $GLOBALS['egw_setup']->db->select('phpgw_lang','app_name,lang,message_id','LENGTH(message_id) > 128',__LINE__,__FILE__,
false,'ORDER BY app_name,lang,message_id'); false,'ORDER BY app_name,lang,message_id');
while(($row = $GLOBALS['egw_setup']->db->row(true))) while(($row = $GLOBALS['egw_setup']->db->row(true)))
@ -621,12 +631,22 @@
{ {
$to_delete[] = $row; $to_delete[] = $row;
} }
else
{
$to_truncate[] = $row;
}
$last_row = $row; $last_row = $row;
} }
foreach ($to_delete as $row) foreach ($to_delete as $row)
{ {
$GLOBALS['egw_setup']->db->delete('phpgw_lang',$row,__LINE__,__FILE__); $GLOBALS['egw_setup']->db->delete('phpgw_lang',$row,__LINE__,__FILE__);
} }
foreach ($to_truncate as $row)
{
$where = $row;
$row['message_id'] = substr($row['message_id'],0,128);
$GLOBALS['egw_setup']->db->update('phpgw_lang',$row,$where,__LINE__,__FILE__,'phpgwapi');
}
$GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_lang','app_name',array( $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_lang','app_name',array(
'type' => 'varchar', 'type' => 'varchar',
'precision' => '32', 'precision' => '32',
@ -640,9 +660,9 @@
'default' => '' 'default' => ''
)); ));
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_lang','egw_lang'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_lang','egw_lang');
$GLOBALS['egw_setup']->lang_table = 'egw_lang'; $GLOBALS['egw_setup']->set_table_names(True);
$GLOBALS['egw_setup']->oProc->RenameTable('phpgw_languages','egw_languages'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_languages','egw_languages');
$GLOBALS['egw_setup']->languages_table = 'egw_languages'; $GLOBALS['egw_setup']->set_table_names(True);
$GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.015'; $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.015';
return $GLOBALS['setup_info']['phpgwapi']['currentver']; return $GLOBALS['setup_info']['phpgwapi']['currentver'];
@ -757,26 +777,28 @@
// (shortening them twice, does no harm) !!! // (shortening them twice, does no harm) !!!
if ($GLOBALS['egw_setup']->table_exist(array('phpgw_felamimail_cache'))) if ($GLOBALS['egw_setup']->table_exist(array('phpgw_felamimail_cache')))
{ {
$GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_cache','fmail_accountname',array( $table_def_cache = $GLOBALS['egw_setup']->oProc->GetTableDefinition('phpgw_felamimail_cache');
$table_def_folderstatus = $GLOBALS['egw_setup']->oProc->GetTableDefinition('phpgw_felamimail_folderstatus');
foreach (array('fmail_accountname','accountname','fmail_foldername','foldername') as $column_name)
{
if (isset($table_def_cache['fd'][$column_name]))
{
$GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_cache',$column_name,array(
'type' => 'varchar', 'type' => 'varchar',
'precision' => '128', 'precision' => '128',
'nullable' => False 'nullable' => False
)); ));
$GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_cache','fmail_foldername',array( }
'type' => 'varchar', if (isset($table_def_folderstatus['fd'][$column_name]))
'precision' => '128', {
'nullable' => False $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_folderstatus',$column_name,array(
));
$GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_folderstatus','fmail_accountname',array(
'type' => 'varchar',
'precision' => '128',
'nullable' => False
));
$GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_folderstatus','fmail_foldername',array(
'type' => 'varchar', 'type' => 'varchar',
'precision' => '128', 'precision' => '128',
'nullable' => False 'nullable' => False
)); ));
}
}
} }
if (substr($GLOBALS['egw_setup']->db->Type,0,5) == 'mysql' && $GLOBALS['egw_setup']->system_charset && $GLOBALS['egw_setup']->db_charset_was && if (substr($GLOBALS['egw_setup']->db->Type,0,5) == 'mysql' && $GLOBALS['egw_setup']->system_charset && $GLOBALS['egw_setup']->db_charset_was &&
$GLOBALS['egw_setup']->system_charset != $GLOBALS['egw_setup']->db_charset_was) $GLOBALS['egw_setup']->system_charset != $GLOBALS['egw_setup']->db_charset_was)

View File

@ -1004,11 +1004,11 @@
* @param array $tables array with possible table-names * @param array $tables array with possible table-names
* @return string/boolean tablename or false * @return string/boolean tablename or false
*/ */
function table_exist($tables) function table_exist($tables,$force_refresh=False)
{ {
static $table_names; static $table_names = False;
if (!$table_names) $table_names = $this->db->table_names(); if (!$table_names || $force_refresh) $table_names = $this->db->table_names();
if (!$table_names) return false; if (!$table_names) return false;
@ -1027,16 +1027,18 @@
* *
* Other tables can always use the most up to date name * Other tables can always use the most up to date name
*/ */
function set_table_names() function set_table_names($force_refresh=False)
{ {
foreach(array( foreach(array(
'config_table' => array('egw_config','phpgw_config','config'), 'config_table' => array('egw_config','phpgw_config','config'),
'applications_table' => array('egw_applications','phpgw_applications','applications'), 'applications_table' => array('egw_applications','phpgw_applications','applications'),
'accounts_table' => array('egw_accounts','phpgw_accounts'),
'acl_table' => array('egw_acl','phpgw_acl'),
'lang_table' => array('egw_lang','phpgw_lang','lang'), 'lang_table' => array('egw_lang','phpgw_lang','lang'),
'languages_table' => array('egw_languages','phpgw_languages','languages'), 'languages_table' => array('egw_languages','phpgw_languages','languages'),
) as $name => $tables) ) as $name => $tables)
{ {
$table = $this->table_exist($tables); $table = $this->table_exist($tables,$force_refresh);
if ($table && $table != $this->$name) // only overwrite the default name, if we realy got one (important for new installs) if ($table && $table != $this->$name) // only overwrite the default name, if we realy got one (important for new installs)
{ {