phpBB

Code Changes

File: includes/functions_install.php

  Unmodified   Added   Modified   Removed
Line 21Line 21
*/
function can_load_dll($dll)
{

*/
function can_load_dll($dll)
{

	return ((@ini_get('enable_dl') || strtolower(@ini_get('enable_dl')) == 'on') && (!@ini_get('safe_mode') || strtolower(@ini_get('safe_mode')) == 'off') && @dl($dll . '.' . PHP_SHLIB_SUFFIX)) ? true : false;














	// SQLite2 is a tricky thing, from 5.0.0 it requires PDO; if PDO is not loaded we must state that SQLite is unavailable
// as the installer doesn't understand that the extension has a prerequisite.
//
// On top of this sometimes the SQLite extension is compiled for a different version of PDO
// by some Linux distributions which causes phpBB to bomb out with a blank page.
//
// Net result we'll disable automatic inclusion of SQLite support
//
// See: r9618 and #56105
if ($dll == 'sqlite')
{
return false;
}
return ((@ini_get('enable_dl') || strtolower(@ini_get('enable_dl')) == 'on') && (!@ini_get('safe_mode') || strtolower(@ini_get('safe_mode')) == 'off') && function_exists('dl') && @dl($dll . '.' . PHP_SHLIB_SUFFIX)) ? true : false;

}

/**

}

/**

Line 42Line 55
			'AVAILABLE'		=> true,
'2.0.x' => false,
),

			'AVAILABLE'		=> true,
'2.0.x' => false,
),

 
		// Note: php 5.5 alpha 2 deprecated mysql.
// Keep mysqli before mysql in this list.

		'mysqli'	=> array(
'LABEL' => 'MySQL with MySQLi Extension',
'SCHEMA' => 'mysql_41',

		'mysqli'	=> array(
'LABEL' => 'MySQL with MySQLi Extension',
'SCHEMA' => 'mysql_41',

Line 81Line 96
			'DRIVER'		=> 'mssql_odbc',
'AVAILABLE' => true,
'2.0.x' => true,

			'DRIVER'		=> 'mssql_odbc',
'AVAILABLE' => true,
'2.0.x' => true,

 
		),
'mssqlnative' => array(
'LABEL' => 'MS SQL Server 2005+ [ Native ]',
'SCHEMA' => 'mssql',
'MODULE' => 'sqlsrv',
'DELIM' => 'GO',
'COMMENTS' => 'remove_comments',
'DRIVER' => 'mssqlnative',
'AVAILABLE' => true,
'2.0.x' => false,

		),
'oracle' => array(
'LABEL' => 'Oracle',

		),
'oracle' => array(
'LABEL' => 'Oracle',

Line 188Line 213

/**
* Get tables of a database


/**
* Get tables of a database

 
*
* @deprecated

*/

*/

function get_tables($db)

function get_tables(&$db)

{

{

	switch ($db->sql_layer)

	if (!class_exists('phpbb_db_tools'))

	{

	{

		case 'mysql':
case 'mysql4':
case 'mysqli':
$sql = 'SHOW TABLES';
break;

case 'sqlite':
$sql = 'SELECT name
FROM sqlite_master
WHERE type = "table"';
break;

case 'mssql':
case 'mssql_odbc':
$sql = "SELECT name
FROM sysobjects
WHERE type='U'";
break;

case 'postgres':
$sql = 'SELECT relname
FROM pg_stat_user_tables';
break;

case 'firebird':
$sql = 'SELECT rdb$relation_name
FROM rdb$relations
WHERE rdb$view_source is null
AND rdb$system_flag = 0';
break;

case 'oracle':
$sql = 'SELECT table_name
FROM USER_TABLES';
break;

		global $phpbb_root_path, $phpEx;
require($phpbb_root_path . 'includes/db/db_tools.' . $phpEx);


































	}


	}


	$result = $db->sql_query($sql);

$tables = array();

while ($row = $db->sql_fetchrow($result))
{
$tables[] = current($row);
}

$db->sql_freeresult($result);

	$db_tools = new phpbb_db_tools($db);














	return $tables;

	return $db_tools->sql_list_tables();

}

/**

}

/**

Line 286Line 271
	{
case 'mysql':
case 'mysqli':

	{
case 'mysql':
case 'mysqli':

			if (strpos($table_prefix, '-') !== false || strpos($table_prefix, '.') !== false)

			if (strspn($table_prefix, '-./\\') !== 0)

			{
$error[] = $lang['INST_ERR_PREFIX_INVALID'];
return false;

			{
$error[] = $lang['INST_ERR_PREFIX_INVALID'];
return false;

Line 300Line 285

case 'mssql':
case 'mssql_odbc':


case 'mssql':
case 'mssql_odbc':

 
		case 'mssqlnative':

			$prefix_length = 90;
break;


			$prefix_length = 90;
break;


Line 323Line 309
	if (is_array($db->sql_connect($dbhost, $dbuser, $dbpasswd, $dbname, $dbport, false, true)))
{
$db_error = $db->sql_error();

	if (is_array($db->sql_connect($dbhost, $dbuser, $dbpasswd, $dbname, $dbport, false, true)))
{
$db_error = $db->sql_error();

		$error[] = $lang['INST_ERR_DB_CONNECT'] . '<br />' . (($db_error['message']) ? $db_error['message'] : $lang['INST_ERR_DB_NO_ERROR']);

		$error[] = $lang['INST_ERR_DB_CONNECT'] . '<br />' . (($db_error['message']) ? utf8_convert_message($db_error['message']) : $lang['INST_ERR_DB_NO_ERROR']);

	}
else
{

	}
else
{

Line 396Line 382
					}
else
{

					}
else
{

						$sql = "SELECT FIRST 0 char_length('')
FROM RDB\$DATABASE";

						$sql = 'SELECT 1 FROM RDB$DATABASE
WHERE BIN_AND(10, 1) = 0';

						$result = $db->sql_query($sql);

						$result = $db->sql_query($sql);

						if (!$result) // This can only fail if char_length is not defined

						if (!$result) // This can only fail if BIN_AND is not defined

						{
$error[] = $lang['INST_ERR_DB_NO_FIREBIRD'];
}

						{
$error[] = $lang['INST_ERR_DB_NO_FIREBIRD'];
}

Line 489Line 475
}

/**

}

/**

* remove_remarks will strip the sql comment lines out of an uploaded sql file



* Removes comments from schema files
*
* @deprecated Use phpbb_remove_comments() instead.

*/
function remove_remarks(&$sql)
{

*/
function remove_remarks(&$sql)
{

 
	// Remove # style comments

	$sql = preg_replace('/\n{2,}/', "\n", preg_replace('/^#.*$/m', "\n", $sql));

	$sql = preg_replace('/\n{2,}/', "\n", preg_replace('/^#.*$/m', "\n", $sql));

 

// Return by reference
}

/**
* Removes "/* style" as well as "# style" comments from $input.
*
* @param string $input Input string
*
* @return string Input string with comments removed
*/
function phpbb_remove_comments($input)
{
if (!function_exists('remove_comments'))
{
global $phpbb_root_path, $phpEx;
require($phpbb_root_path . 'includes/functions_admin.' . $phpEx);
}

// Remove /* */ comments
remove_comments($input);

// Remove # style comments
remove_remarks($input);

return $input;

}

/**

}

/**

Line 529Line 544

return (!empty($lang[$matches[1]])) ? $db->sql_escape($lang[$matches[1]]) : $db->sql_escape($matches[1]);
}


return (!empty($lang[$matches[1]])) ? $db->sql_escape($lang[$matches[1]]) : $db->sql_escape($matches[1]);
}

 
}

/**
* Creates the output to be stored in a phpBB config.php file
*
* @param array $data Array containing the database connection information
* @param string $dbms The name of the DBAL class to use
* @param array $load_extensions Array of additional extensions that should be loaded
* @param bool $debug If the debug constants should be enabled by default or not
* @param bool $debug_test If the DEBUG_TEST constant should be added
* NOTE: Only for use within the testing framework
*
* @return string The output to write to the file
*/
function phpbb_create_config_file_data($data, $dbms, $load_extensions, $debug = false, $debug_test = false)
{
$load_extensions = implode(',', $load_extensions);

$config_data = "<?php\n";
$config_data .= "// phpBB 3.0.x auto-generated configuration file\n// Do not change anything in this file!\n";

$config_data_array = array(
'dbms' => $dbms,
'dbhost' => $data['dbhost'],
'dbport' => $data['dbport'],
'dbname' => $data['dbname'],
'dbuser' => $data['dbuser'],
'dbpasswd' => htmlspecialchars_decode($data['dbpasswd']),
'table_prefix' => $data['table_prefix'],
'acm_type' => 'file',
'load_extensions' => $load_extensions,
);

foreach ($config_data_array as $key => $value)
{
$config_data .= "\${$key} = '" . str_replace("'", "\\'", str_replace('\\', '\\\\', $value)) . "';\n";
}

$config_data .= "\n@define('PHPBB_INSTALLED', true);\n";

if ($debug)
{
$config_data .= "@define('DEBUG', true);\n";
$config_data .= "@define('DEBUG_EXTRA', true);\n";
}
else
{
$config_data .= "// @define('DEBUG', true);\n";
$config_data .= "// @define('DEBUG_EXTRA', true);\n";
}

if ($debug_test)
{
$config_data .= "@define('DEBUG_TEST', true);\n";
}

return $config_data;

}

?>

}

?>