True, 'nonavbar' => True, 'currentapp' => 'home', 'noapi' => True ); include('./inc/functions.inc.php'); // Authorize the user to use setup app and load the database // Does not return unless user is authorized if (!$GLOBALS['phpgw_setup']->auth('Config') || @$_POST['cancel']) { Header('Location: index.php'); exit; } $GLOBALS['phpgw_setup']->loaddb(); $translation = &$GLOBALS['phpgw_setup']->translation->sql; $tpl_root = $GLOBALS['phpgw_setup']->html->setup_tpl_dir('setup'); $setup_tpl = CreateObject('phpgwapi.Template',$tpl_root); $setup_tpl->set_file(array( 'T_head' => 'head.tpl', 'T_footer' => 'footer.tpl', 'T_system_charset' => 'system_charset.tpl', )); $stage_title = lang('Change system-charset'); $stage_desc = lang('This program will convert your database to a new system-charset.'); $GLOBALS['phpgw_setup']->html->show_header($stage_title,False,'config',$ConfigDomain . '(' . $phpgw_domain[$ConfigDomain]['db_type'] . ')'); if (@$_POST['convert']) { if (empty($_POST['current_charset'])) { $errors[] = lang('You need to select your current charset!'); } else { $debug=1; convert_db($_POST['current_charset'],$_POST['new_charset'],$debug); if (!$debug) { Header('Location: index.php'); } echo "

Database successfully converted from '$_POST[current_charset]' to '$_POST[new_charset]'

\n"; echo "

Click here to return to setup

\n"; exit; } } function key_data_implode($glue,$array,$only=False,$use_key=True) { $pairs = array(); foreach($array as $key => $data) { if (!$only || in_array($key,$only)) { $values[] = ($use_key ? $key.'=' : '')."'".addslashes($data)."'"; } } return implode($glue,$values); } function convert_db($from,$to,$debug=1) { if ($debug) echo "

Converting database from '$from' to '$to'

\n"; @set_time_limit(0); // this might take a while $db2 = $GLOBALS['phpgw_setup']->db; $setup_info = $GLOBALS['phpgw_setup']->detection->get_versions(); $setup_info = $GLOBALS['phpgw_setup']->detection->get_db_versions($setup_info); // Visit each app/setup dir, look for a phpgw_lang file foreach($setup_info as $app => $data) { $tables_current = PHPGW_SERVER_ROOT . "/$app/setup/tables_current.inc.php"; if ($debug) echo "

$app: "; if (!isset($data['tables']) || !count($data['tables']) || $GLOBALS['phpgw_setup']->app_registered($app) && !file_exists($tables_current)) { if ($debug) echo "skipping (no tables or not installed)

\n"; continue; } include($tables_current); foreach($phpgw_baseline as $table => $definition) { if ($debug) { echo "
start converting table '$table' ... "; flush(); } $updates = 0; $GLOBALS['phpgw_setup']->db->query("SELECT * FROM $table",__LINE__,__FILE__); while($GLOBALS['phpgw_setup']->db->next_record()) { $columns = $GLOBALS['phpgw_setup']->db->Record; $update = array(); foreach($columns as $name => $data) { if (is_numeric($name)) { unset($columns[$name]); continue; } switch($definition['fd'][$name]['type']) { case 'char': case 'varchar': case 'text': case 'longtext': $converted = $GLOBALS['translation']->convert($data,$from,$to); if ($converted != $data) { $update[$name] = $converted; } break; } } if (count($update)) { if (count($definition['pk'])) { $db2->query($query="UPDATE $table SET ".key_data_implode(',',$update)." WHERE ".key_data_implode(' AND ',$columns,$definition['pk']),__LINE__,__FILE__); } else { $db2->query($query="DELETE FROM $table WHERE ".key_data_implode(' AND ',$columns),__LINE__,__FILE__); if ($debug > 1) echo "   $query
\n"; $db2->query($query="INSERT INTO $table (".implode(',',array_keys($columns)).") VALUES (".key_data_implode(',',array_merge($columns,$update),False,True).")",__LINE__,__FILE__); } if ($debug > 1) echo "   $query

\n"; ++$updates; } } if ($debug) { $GLOBALS['phpgw_setup']->db->query("SELECT count(*) FROM $table",__LINE__,__FILE__); $GLOBALS['phpgw_setup']->db->next_record(); $total = $GLOBALS['phpgw_setup']->db->f(0); echo " done, $updates/$total rows updated"; } } } @$GLOBALS['phpgw_setup']->db->query("DELETE FROM phpgw_config WHERE config_app='phpgwapi' AND config_name='system_charset'",__LINE__,__FILE__); $GLOBALS['phpgw_setup']->db->query("INSERT INTO phpgw_config (config_app,config_name,config_value) VALUES ('phpgwapi','system_charset','$to')",__LINE__,__FILE__); } $setup_tpl->set_var('stage_title',$stage_title); $setup_tpl->set_var('stage_desc',$stage_desc); $setup_tpl->set_var('error_msg',is_array($errors) ? implode('
',$errors) : ' '); $setup_tpl->set_var('lang_convert',lang('Convert')); $setup_tpl->set_var('lang_cancel',lang('Cancel')); $setup_tpl->set_var('lang_current',lang('Current system-charset')); $setup_tpl->set_var('lang_convert_to',lang('Charset to convert to')); $setup_tpl->set_var('lang_warning',lang('Warning: Hopefully you know what you do ;-)')); $installed_charsets = $translation->get_installed_charsets(); if ($translation->system_charset || count($installed_charsets) == 1) { reset($installed_charsets); list($current_charset) = each($installed_charsets); if ($translation->system_charset) { $current_charset = $translation->system_charset; } $setup_tpl->set_var('current_charset',"$current_charset". "\n"); } else { $options = '\n"; foreach($installed_charsets as $charset => $description) { $options .= "\n"; } $setup_tpl->set_var('current_charset',"\n"); } if ($translation->system_charset == 'utf8' || count($installed_charsets) == 1) { reset($installed_charsets); list($other_charset) = each($installed_charsets); if (!$translation->system_charset || $other_charset == $translation->system_charset) { $other_charset = 'utf8'; } $setup_tpl->set_var('new_charset',"$other_charset\n"); } else { if ($translation->system_charset != 'utf8') { $options = '\n"; } foreach($installed_charsets as $charset => $description) { if ($charset != $translation->system_charset) { $options .= "\n"; } } $setup_tpl->set_var('new_charset',"\n"); } $setup_tpl->pparse('out','T_system_charset'); $GLOBALS['phpgw_setup']->html->show_footer(); ?>