' . "\n" . '' . $GLOBALS['strDocu'] . '' . "\n"; exit; } // MySQL client API if (!defined('PMA_MYSQL_CLIENT_API')) { $client_api = explode('.', mysql_get_client_info()); define('PMA_MYSQL_CLIENT_API', (int)sprintf('%d%02d%02d', $client_api[0], $client_api[1], intval($client_api[2]))); unset($client_api); } function PMA_DBI_connect($user, $password) { global $cfg, $php_errormsg; $server_port = (empty($cfg['Server']['port'])) ? '' : ':' . $cfg['Server']['port']; if (strtolower($cfg['Server']['connect_type']) == 'tcp') { $cfg['Server']['socket'] = ''; } $server_socket = (empty($cfg['Server']['socket'])) ? '' : ':' . $cfg['Server']['socket']; if (PMA_MYSQL_CLIENT_API >= 32349) { $client_flags = $cfg['Server']['compress'] && defined('MYSQL_CLIENT_COMPRESS') ? MYSQL_CLIENT_COMPRESS : 0; } if (empty($client_clags)) { $connect_func = 'mysql_' . ($cfg['PersistentConnections'] ? 'p' : '') . 'connect'; $link = @$connect_func($cfg['Server']['host'] . $server_port . $server_socket, $user, $password); } else { if ($cfg['PersistentConnections']) { $link = @mysql_pconnect($cfg['Server']['host'] . $server_port . $server_socket, $user, $password, $client_flags); } else { $link = @mysql_connect($cfg['Server']['host'] . $server_port . $server_socket, $user, $password, FALSE, $client_flags); } } if (empty($link)) { PMA_auth_fails(); } // end if if (!defined('PMA_MYSQL_INT_VERSION')) { $result = PMA_DBI_try_query('SELECT VERSION() AS version', $link); if ($result != FALSE && @mysql_num_rows($result) > 0) { $row = PMA_DBI_fetch_assoc($result); $match = explode('.', $row['version']); mysql_free_result($result); } if (!isset($row)) { define('PMA_MYSQL_INT_VERSION', 32332); define('PMA_MYSQL_STR_VERSION', '3.23.32'); } else{ define('PMA_MYSQL_INT_VERSION', (int)sprintf('%d%02d%02d', $match[0], $match[1], intval($match[2]))); define('PMA_MYSQL_STR_VERSION', $row['version']); unset($result, $row, $match); } } return $link; } function PMA_DBI_try_query($query, $link = '') { if (empty($link)) { if (isset($GLOBALS['userlink'])) { $link = $GLOBALS['userlink']; } else { return FALSE; } } return mysql_query(PMA_convert_charset($query), $link); } // The following function is meant for internal use only. // Do not call it from outside this library! function PMA_mysql_fetch_array($result, $type = FALSE) { global $cfg, $allow_recoding, $charset, $convcharset; if ($type != FALSE) { $data = mysql_fetch_array($result, $type); } else { $data = mysql_fetch_array($result); } if (!(isset($cfg['AllowAnywhereRecoding']) && $cfg['AllowAnywhereRecoding'] && $allow_recoding)) { /* No recoding -> return data as we got them */ return $data; } else { $ret = array(); $num = mysql_num_fields($result); $i = 0; for($i = 0; $i < $num; $i++) { $meta = mysql_fetch_field($result); $name = mysql_field_name($result, $i); if (!$meta) { /* No meta information available -> we guess that it should be converted */ if (isset($data[$i])) $ret[$i] = PMA_convert_display_charset($data[$i]); if (isset($data[$name])) $ret[PMA_convert_display_charset($name)] = PMA_convert_display_charset($data[$name]); } else { /* Meta information available -> check type of field and convert it according to the type */ if ($meta->blob || stristr($meta->type, 'BINARY')) { if (isset($data[$i])) $ret[$i] = $data[$i]; if (isset($data[$name])) $ret[PMA_convert_display_charset($name)] = $data[$name]; } else { if (isset($data[$i])) $ret[$i] = PMA_convert_display_charset($data[$i]); if (isset($data[$name])) $ret[PMA_convert_display_charset($name)] = PMA_convert_display_charset($data[$name]); } } } return $ret; } } function PMA_DBI_fetch_assoc($result) { return PMA_mysql_fetch_array($result, MYSQL_ASSOC); } function PMA_DBI_fetch_row($result) { return PMA_mysql_fetch_array($result, MYSQL_NUM); } function PMA_DBI_free_result($result) { return mysql_free_result($result); } function PMA_DBI_getError($link = '') { if (empty($link)) { if (isset($GLOBALS['userlink'])) { $link = $GLOBALS['userlink']; } else { return FALSE; } } $error = mysql_errno($link); if ($error) { $error = mysql_errno($link); if (!empty($error)) { $error = '#' . ((string) $error) . ' - ' . PMA_convert_display_charset(mysql_error($link)); } } } function PMA_DBI_close($link = '') { if (empty($link)) { $link = $GLOBALS['userlink']; } @mysql_close($link); } function PMA_DBI_get_dblist($link = '') { if (empty($link)) { $link = $GLOBALS['userlink']; } $res = PMA_DBI_try_query('SHOW DATABASES;', $link); $dbs_array = array(); while ($row = PMA_DBI_fetch_row($res)) { // not sure if we have to convert before the (possible) select_db() $dbname = PMA_convert_display_charset($row[0]); // Before MySQL 4.0.2, SHOW DATABASES could send the // whole list, so check if we really have access: if (PMA_MYSQL_CLIENT_API < 40002) { $dblink = @PMA_mysql_select_db($dbname); if (!dblink) { continue; } } $dbs_array[] = $dbname; } PMA_DBI_free_result($res); unset($res); return $dbs_array; } ?>