* Copyright (C) 2004-2011 Laurent Destailleur * Copyright (C) 2004 Sebastien Di Cintio * Copyright (C) 2004 Benoit Mortier * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ /** * \file htdocs/admin/system/database.php * \brief Page with system information of database */ require("../../main.inc.php"); $langs->load("admin"); if (!$user->admin) accessforbidden(); /* * View */ $form=new Form($db); llxHeader(); print_fiche_titre($langs->trans("DatabaseConfiguration"),'','setup'); // Database print ''; print ''."\n"; print ''."\n"; print ''."\n"; print ''."\n"; print ''."\n"; print ''."\n"; print ''."\n"; print ''."\n"; print ''."\n"; print ''."\n"; print '
'.$langs->trans("Database").'
'.$langs->trans("Version").''.getStaticMember(get_class($db),'label').' '.$db->getVersion().'
'.$langs->trans("DatabaseServer").''.$conf->db->host.'
'.$langs->trans("DatabasePort").''.(empty($conf->db->port)?$langs->trans("Default"):$conf->db->port).'
'.$langs->trans("DatabaseName").''.$conf->db->name.'
'.$langs->trans("DriverType").''.$conf->db->type .'
'.$langs->trans("User").''.$conf->db->user.'
'.$langs->trans("Password").''.preg_replace('/./i','*',$dolibarr_main_db_pass).'
'.$langs->trans("DBStoringCharset").''.$db->getDefaultCharacterSetDatabase().'
'.$langs->trans("DBSortingCharset").''.$db->getDefaultCollationDatabase().'
'; $base=0; $sqls = array(); if ($conf->db->type == 'mysql' || $conf->db->type == 'mysqli') { $sqls[0] = "SHOW VARIABLES"; // TODO Use function getServerParametersValues $sqls[1] = "SHOW STATUS"; // TODO Use function getServerStatusValues $base=1; } else if ($conf->db->type == 'pgsql') { $sqls[0] = "select name,setting from pg_settings"; $base=2; } else if ($conf->db->type == 'mssql') { //$sqls[0] = ""; //$base=3; } if (! $base) { print $langs->trans("FeatureNotAvailableWithThisDatabaseDriver"); } else { foreach($sqls as $sql) { print '
'; print ''; print ''; print ''; print ''; print ''."\n"; // arraytest is an array of test to do $arraytest=array(); if (preg_match('/mysql/i',$db->type)) { $arraytest=array( // "character_set_connection"=>'UTF-8', 'character_set_database'=>'dolibarr_main_db_character_set', // 'collation_connection'=>"UTF-8", 'collation_database'=>'dolibarr_main_db_collation' ); } $resql = $db->query($sql); if ($resql) { $var=True; while ($row = $db->fetch_row($resql)) { $var=!$var; print ''; print ''; print ''; print ''."\n"; } $db->free($resql); } print '
'.$langs->trans("Parameter").''.$langs->trans("Value").'
'; print $row[0]; print ''; $show=0;$text=''; foreach($arraytest as $key => $val) { if ($key != $row[0]) continue; $text='Should be in line with value of param '.$val.' thas is '.${$val}.''; $show=1; } if ($show==0) print $row[1]; if ($show==1) print $form->textwithpicto($row[1],$text); if ($show==2) print $form->textwithpicto($row[1],$text,1,'warning'); print '
'."\n"; } } llxFooter(); ?>