Skip to content

Commit

Permalink
BUGFIX Updating MySQLDatabaseConfigurationHelper to check for MySQLi
Browse files Browse the repository at this point in the history
instead of mysql_connect and other old function usage, as we've moved to
MySQLi in MySQLDatabase.php now
  • Loading branch information
halkyon committed Apr 28, 2012
1 parent c7ca63e commit b03cf04
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 15 deletions.
2 changes: 1 addition & 1 deletion _register_database.php
Expand Up @@ -8,7 +8,7 @@
'class' => 'MySQLDatabase', 'class' => 'MySQLDatabase',
'title' => 'MySQL 5.0+', 'title' => 'MySQL 5.0+',
'helperPath' => $frameworkPath . '/dev/install/MySQLDatabaseConfigurationHelper.php', 'helperPath' => $frameworkPath . '/dev/install/MySQLDatabaseConfigurationHelper.php',
'supported' => function_exists('mysql_connect'), 'supported' => class_exists('MySQLi'),
) )
); );


Expand Down
28 changes: 14 additions & 14 deletions dev/install/MySQLDatabaseConfigurationHelper.php
Expand Up @@ -18,7 +18,7 @@ class MySQLDatabaseConfigurationHelper implements DatabaseConfigurationHelper {
* @return boolean * @return boolean
*/ */
public function requireDatabaseFunctions($databaseConfig) { public function requireDatabaseFunctions($databaseConfig) {
return (function_exists('mysql_connect')) ? true : false; return class_exists('MySQLi');
} }


/** /**
Expand All @@ -29,12 +29,12 @@ public function requireDatabaseFunctions($databaseConfig) {
public function requireDatabaseServer($databaseConfig) { public function requireDatabaseServer($databaseConfig) {
$success = false; $success = false;
$error = ''; $error = '';
$conn = @mysql_connect($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']); $conn = new MySQLi($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']);
if($conn || mysql_errno() < 2000) { if($conn && $conn->connect_errno < 2000) {
$success = true; $success = true;
} else { } else {
$success = false; $success = false;
$error = mysql_error(); $error = ($conn) ? $conn->connect_error : '';
} }
return array( return array(
'success' => $success, 'success' => $success,
Expand All @@ -48,13 +48,13 @@ public function requireDatabaseServer($databaseConfig) {
* @return mixed string Version number as string | boolean FALSE on failure * @return mixed string Version number as string | boolean FALSE on failure
*/ */
public function getDatabaseVersion($databaseConfig) { public function getDatabaseVersion($databaseConfig) {
$conn = @mysql_connect($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']); $conn = new MySQLi($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']);
if(!$conn) return false; if(!$conn) return false;
$version = @mysql_get_server_info($conn); $version = $conn->server_info;
if(!$version) { if(!$version) {
// fallback to trying a query // fallback to trying a query
$result = @mysql_query("SELECT VERSION()"); $result = $conn->query('SELECT VERSION()');
$row = @mysql_fetch_array($result); $row = $result->fetch_array();
if($row && isset($row[0])) { if($row && isset($row[0])) {
$version = trim($row[0]); $version = trim($row[0]);
} }
Expand Down Expand Up @@ -93,12 +93,12 @@ public function requireDatabaseVersion($databaseConfig) {
public function requireDatabaseConnection($databaseConfig) { public function requireDatabaseConnection($databaseConfig) {
$success = false; $success = false;
$error = ''; $error = '';
$conn = @mysql_connect($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']); $conn = new MySQLi($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']);
if($conn) { if($conn) {
$success = true; $success = true;
} else { } else {
$success = false; $success = false;
$error = mysql_error(); $error = ($conn) ? $conn->connect_error : '';
} }
return array( return array(
'success' => $success, 'success' => $success,
Expand All @@ -116,13 +116,13 @@ public function requireDatabaseConnection($databaseConfig) {
public function requireDatabaseOrCreatePermissions($databaseConfig) { public function requireDatabaseOrCreatePermissions($databaseConfig) {
$success = false; $success = false;
$alreadyExists = false; $alreadyExists = false;
$conn = @mysql_connect($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']); $conn = new MySQLi($databaseConfig['server'], $databaseConfig['username'], $databaseConfig['password']);
if(@mysql_select_db($databaseConfig['database'], $conn)) { if($conn && $conn->select_db($databaseConfig['database'])) {
$success = true; $success = true;
$alreadyExists = true; $alreadyExists = true;
} else { } else {
if(@mysql_query("CREATE DATABASE testing123", $conn)) { if($conn && $conn->query('CREATE DATABASE testing123')) {
mysql_query("DROP DATABASE testing123", $conn); mysql_query('DROP DATABASE testing123', $conn);
$success = true; $success = true;
$alreadyExists = false; $alreadyExists = false;
} }
Expand Down

0 comments on commit b03cf04

Please sign in to comment.