Blame Identity/Models/Html/phpBB/3.0.4/includes/functions_install.php

d6e8d8
d6e8d8
/**
d6e8d8
*
d6e8d8
* @package install
d6e8d8
* @version $Id: functions_install.php 8507 2008-04-20 04:57:29Z davidmj $
d6e8d8
* @copyright (c) 2006 phpBB Group
d6e8d8
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
d6e8d8
*
d6e8d8
*/
d6e8d8
d6e8d8
/**
d6e8d8
* @ignore
d6e8d8
*/
d6e8d8
if (!defined('IN_PHPBB'))
d6e8d8
{
d6e8d8
	exit;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* Determine if we are able to load a specified PHP module and do so if possible
d6e8d8
*/
d6e8d8
function can_load_dll($dll)
d6e8d8
{
d6e8d8
	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;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* Returns an array of available DBMS with some data, if a DBMS is specified it will only
d6e8d8
* return data for that DBMS and will load its extension if necessary.
d6e8d8
*/
d6e8d8
function get_available_dbms($dbms = false, $return_unavailable = false, $only_20x_options = false)
d6e8d8
{
d6e8d8
	global $lang;
d6e8d8
	$available_dbms = array(
d6e8d8
		'firebird'	=> array(
d6e8d8
			'LABEL'			=> 'FireBird',
d6e8d8
			'SCHEMA'		=> 'firebird',
d6e8d8
			'MODULE'		=> 'interbase',
d6e8d8
			'DELIM'			=> ';;',
d6e8d8
			'COMMENTS'		=> 'remove_remarks',
d6e8d8
			'DRIVER'		=> 'firebird',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> false,
d6e8d8
		),
d6e8d8
		'mysqli'	=> array(
d6e8d8
			'LABEL'			=> 'MySQL with MySQLi Extension',
d6e8d8
			'SCHEMA'		=> 'mysql_41',
d6e8d8
			'MODULE'		=> 'mysqli',
d6e8d8
			'DELIM'			=> ';',
d6e8d8
			'COMMENTS'		=> 'remove_remarks',
d6e8d8
			'DRIVER'		=> 'mysqli',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> true,
d6e8d8
		),
d6e8d8
		'mysql'		=> array(
d6e8d8
			'LABEL'			=> 'MySQL',
d6e8d8
			'SCHEMA'		=> 'mysql',
d6e8d8
			'MODULE'		=> 'mysql',
d6e8d8
			'DELIM'			=> ';',
d6e8d8
			'COMMENTS'		=> 'remove_remarks',
d6e8d8
			'DRIVER'		=> 'mysql',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> true,
d6e8d8
		),
d6e8d8
		'mssql'		=> array(
d6e8d8
			'LABEL'			=> 'MS SQL Server 2000+',
d6e8d8
			'SCHEMA'		=> 'mssql',
d6e8d8
			'MODULE'		=> 'mssql',
d6e8d8
			'DELIM'			=> 'GO',
d6e8d8
			'COMMENTS'		=> 'remove_comments',
d6e8d8
			'DRIVER'		=> 'mssql',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> true,
d6e8d8
		),
d6e8d8
		'mssql_odbc'=>	array(
d6e8d8
			'LABEL'			=> 'MS SQL Server [ ODBC ]',
d6e8d8
			'SCHEMA'		=> 'mssql',
d6e8d8
			'MODULE'		=> 'odbc',
d6e8d8
			'DELIM'			=> 'GO',
d6e8d8
			'COMMENTS'		=> 'remove_comments',
d6e8d8
			'DRIVER'		=> 'mssql_odbc',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> true,
d6e8d8
		),
d6e8d8
		'oracle'	=>	array(
d6e8d8
			'LABEL'			=> 'Oracle',
d6e8d8
			'SCHEMA'		=> 'oracle',
d6e8d8
			'MODULE'		=> 'oci8',
d6e8d8
			'DELIM'			=> '/',
d6e8d8
			'COMMENTS'		=> 'remove_comments',
d6e8d8
			'DRIVER'		=> 'oracle',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> false,
d6e8d8
		),
d6e8d8
		'postgres' => array(
d6e8d8
			'LABEL'			=> 'PostgreSQL 7.x/8.x',
d6e8d8
			'SCHEMA'		=> 'postgres',
d6e8d8
			'MODULE'		=> 'pgsql',
d6e8d8
			'DELIM'			=> ';',
d6e8d8
			'COMMENTS'		=> 'remove_comments',
d6e8d8
			'DRIVER'		=> 'postgres',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> true,
d6e8d8
		),
d6e8d8
		'sqlite'		=> array(
d6e8d8
			'LABEL'			=> 'SQLite',
d6e8d8
			'SCHEMA'		=> 'sqlite',
d6e8d8
			'MODULE'		=> 'sqlite',
d6e8d8
			'DELIM'			=> ';',
d6e8d8
			'COMMENTS'		=> 'remove_remarks',
d6e8d8
			'DRIVER'		=> 'sqlite',
d6e8d8
			'AVAILABLE'		=> true,
d6e8d8
			'2.0.x'			=> false,
d6e8d8
		),
d6e8d8
	);
d6e8d8
d6e8d8
	if ($dbms)
d6e8d8
	{
d6e8d8
		if (isset($available_dbms[$dbms]))
d6e8d8
		{
d6e8d8
			$available_dbms = array($dbms => $available_dbms[$dbms]);
d6e8d8
		}
d6e8d8
		else
d6e8d8
		{
d6e8d8
			return array();
d6e8d8
		}
d6e8d8
	}
d6e8d8
d6e8d8
	// now perform some checks whether they are really available
d6e8d8
	foreach ($available_dbms as $db_name => $db_ary)
d6e8d8
	{
d6e8d8
		if ($only_20x_options && !$db_ary['2.0.x'])
d6e8d8
		{
d6e8d8
			if ($return_unavailable)
d6e8d8
			{
d6e8d8
				$available_dbms[$db_name]['AVAILABLE'] = false;
d6e8d8
			}
d6e8d8
			else
d6e8d8
			{
d6e8d8
				unset($available_dbms[$db_name]);
d6e8d8
			}
d6e8d8
			continue;
d6e8d8
		}
d6e8d8
d6e8d8
		$dll = $db_ary['MODULE'];
d6e8d8
d6e8d8
		if (!@extension_loaded($dll))
d6e8d8
		{
d6e8d8
			if (!can_load_dll($dll))
d6e8d8
			{
d6e8d8
				if ($return_unavailable)
d6e8d8
				{
d6e8d8
					$available_dbms[$db_name]['AVAILABLE'] = false;
d6e8d8
				}
d6e8d8
				else
d6e8d8
				{
d6e8d8
					unset($available_dbms[$db_name]);
d6e8d8
				}
d6e8d8
				continue;
d6e8d8
			}
d6e8d8
		}
d6e8d8
		$any_db_support = true;
d6e8d8
	}
d6e8d8
d6e8d8
	if ($return_unavailable)
d6e8d8
	{
d6e8d8
		$available_dbms['ANY_DB_SUPPORT'] = $any_db_support;
d6e8d8
	}
d6e8d8
	return $available_dbms;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* Generate the drop down of available database options
d6e8d8
*/
d6e8d8
function dbms_select($default = '', $only_20x_options = false)
d6e8d8
{
d6e8d8
	global $lang;
d6e8d8
	
d6e8d8
	$available_dbms = get_available_dbms(false, false, $only_20x_options);
d6e8d8
	$dbms_options = '';
d6e8d8
	foreach ($available_dbms as $dbms_name => $details)
d6e8d8
	{
d6e8d8
		$selected = ($dbms_name == $default) ? ' selected="selected"' : '';
d6e8d8
		$dbms_options .= '<option value="' . $dbms_name . '"' . $selected .'>' . $lang['DLL_' . strtoupper($dbms_name)] . '</option>';
d6e8d8
	}
d6e8d8
	return $dbms_options;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* Get tables of a database
d6e8d8
*/
d6e8d8
function get_tables($db)
d6e8d8
{
d6e8d8
	switch ($db->sql_layer)
d6e8d8
	{
d6e8d8
		case 'mysql':
d6e8d8
		case 'mysql4':
d6e8d8
		case 'mysqli':
d6e8d8
			$sql = 'SHOW TABLES';
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'sqlite':
d6e8d8
			$sql = 'SELECT name
d6e8d8
				FROM sqlite_master
d6e8d8
				WHERE type = "table"';
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'mssql':
d6e8d8
		case 'mssql_odbc':
d6e8d8
			$sql = "SELECT name
d6e8d8
				FROM sysobjects
d6e8d8
				WHERE type='U'";
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'postgres':
d6e8d8
			$sql = 'SELECT relname
d6e8d8
				FROM pg_stat_user_tables';
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'firebird':
d6e8d8
			$sql = 'SELECT rdb$relation_name
d6e8d8
				FROM rdb$relations
d6e8d8
				WHERE rdb$view_source is null
d6e8d8
					AND rdb$system_flag = 0';
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'oracle':
d6e8d8
			$sql = 'SELECT table_name
d6e8d8
				FROM USER_TABLES';
d6e8d8
		break;
d6e8d8
	}
d6e8d8
d6e8d8
	$result = $db->sql_query($sql);
d6e8d8
d6e8d8
	$tables = array();
d6e8d8
d6e8d8
	while ($row = $db->sql_fetchrow($result))
d6e8d8
	{
d6e8d8
		$tables[] = current($row);
d6e8d8
	}
d6e8d8
d6e8d8
	$db->sql_freeresult($result);
d6e8d8
d6e8d8
	return $tables;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* Used to test whether we are able to connect to the database the user has specified
d6e8d8
* and identify any problems (eg there are already tables with the names we want to use
d6e8d8
* @param	array	$dbms should be of the format of an element of the array returned by {@link get_available_dbms get_available_dbms()}
d6e8d8
*					necessary extensions should be loaded already
d6e8d8
*/
d6e8d8
function connect_check_db($error_connect, &$error, $dbms_details, $table_prefix, $dbhost, $dbuser, $dbpasswd, $dbname, $dbport, $prefix_may_exist = false, $load_dbal = true, $unicode_check = true)
d6e8d8
{
d6e8d8
	global $phpbb_root_path, $phpEx, $config, $lang;
d6e8d8
d6e8d8
	$dbms = $dbms_details['DRIVER'];
d6e8d8
d6e8d8
	if ($load_dbal)
d6e8d8
	{
d6e8d8
		// Include the DB layer
d6e8d8
		include($phpbb_root_path . 'includes/db/' . $dbms . '.' . $phpEx);
d6e8d8
	}
d6e8d8
d6e8d8
	// Instantiate it and set return on error true
d6e8d8
	$sql_db = 'dbal_' . $dbms;
d6e8d8
	$db = new $sql_db();
d6e8d8
	$db->sql_return_on_error(true);
d6e8d8
d6e8d8
	// Check that we actually have a database name before going any further.....
d6e8d8
	if ($dbms_details['DRIVER'] != 'sqlite' && $dbms_details['DRIVER'] != 'oracle' && $dbname === '')
d6e8d8
	{
d6e8d8
		$error[] = $lang['INST_ERR_DB_NO_NAME'];
d6e8d8
		return false;
d6e8d8
	}
d6e8d8
d6e8d8
	// Make sure we don't have a daft user who thinks having the SQLite database in the forum directory is a good idea
d6e8d8
	if ($dbms_details['DRIVER'] == 'sqlite' && stripos(phpbb_realpath($dbhost), phpbb_realpath('../')) === 0)
d6e8d8
	{
d6e8d8
		$error[] = $lang['INST_ERR_DB_FORUM_PATH'];
d6e8d8
		return false;
d6e8d8
	}
d6e8d8
d6e8d8
	// Check the prefix length to ensure that index names are not too long and does not contain invalid characters
d6e8d8
	switch ($dbms_details['DRIVER'])
d6e8d8
	{
d6e8d8
		case 'mysql':
d6e8d8
		case 'mysqli':
d6e8d8
			if (strspn($table_prefix, '-./\\') !== 0)
d6e8d8
			{
d6e8d8
				$error[] = $lang['INST_ERR_PREFIX_INVALID'];
d6e8d8
				return false;
d6e8d8
			}
d6e8d8
d6e8d8
		// no break;
d6e8d8
d6e8d8
		case 'postgres':
d6e8d8
			$prefix_length = 36;
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'mssql':
d6e8d8
		case 'mssql_odbc':
d6e8d8
			$prefix_length = 90;
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'sqlite':
d6e8d8
			$prefix_length = 200;
d6e8d8
		break;
d6e8d8
d6e8d8
		case 'firebird':
d6e8d8
		case 'oracle':
d6e8d8
			$prefix_length = 6;
d6e8d8
		break;
d6e8d8
	}
d6e8d8
d6e8d8
	if (strlen($table_prefix) > $prefix_length)
d6e8d8
	{
d6e8d8
		$error[] = sprintf($lang['INST_ERR_PREFIX_TOO_LONG'], $prefix_length);
d6e8d8
		return false;
d6e8d8
	}
d6e8d8
d6e8d8
	// Try and connect ...
d6e8d8
	if (is_array($db->sql_connect($dbhost, $dbuser, $dbpasswd, $dbname, $dbport, false, true)))
d6e8d8
	{
d6e8d8
		$db_error = $db->sql_error();
d6e8d8
		$error[] = $lang['INST_ERR_DB_CONNECT'] . '
' . (($db_error['message']) ? $db_error['message'] : $lang['INST_ERR_DB_NO_ERROR']);
d6e8d8
	}
d6e8d8
	else
d6e8d8
	{
d6e8d8
		// Likely matches for an existing phpBB installation
d6e8d8
		if (!$prefix_may_exist)
d6e8d8
		{
d6e8d8
			$temp_prefix = strtolower($table_prefix);
d6e8d8
			$table_ary = array($temp_prefix . 'attachments', $temp_prefix . 'config', $temp_prefix . 'sessions', $temp_prefix . 'topics', $temp_prefix . 'users');
d6e8d8
d6e8d8
			$tables = get_tables($db);
d6e8d8
			$tables = array_map('strtolower', $tables);
d6e8d8
			$table_intersect = array_intersect($tables, $table_ary);
d6e8d8
d6e8d8
			if (sizeof($table_intersect))
d6e8d8
			{
d6e8d8
				$error[] = $lang['INST_ERR_PREFIX'];
d6e8d8
			}
d6e8d8
		}
d6e8d8
d6e8d8
		// Make sure that the user has selected a sensible DBAL for the DBMS actually installed
d6e8d8
		switch ($dbms_details['DRIVER'])
d6e8d8
		{
d6e8d8
			case 'mysqli':
d6e8d8
				if (version_compare(mysqli_get_server_info($db->db_connect_id), '4.1.3', '<'))
d6e8d8
				{
d6e8d8
					$error[] = $lang['INST_ERR_DB_NO_MYSQLI'];
d6e8d8
				}
d6e8d8
			break;
d6e8d8
d6e8d8
			case 'sqlite':
d6e8d8
				if (version_compare(sqlite_libversion(), '2.8.2', '<'))
d6e8d8
				{
d6e8d8
					$error[] = $lang['INST_ERR_DB_NO_SQLITE'];
d6e8d8
				}
d6e8d8
			break;
d6e8d8
d6e8d8
			case 'firebird':
d6e8d8
				// check the version of FB, use some hackery if we can't get access to the server info
d6e8d8
				if ($db->service_handle !== false && function_exists('ibase_server_info'))
d6e8d8
				{
d6e8d8
					$val = @ibase_server_info($db->service_handle, IBASE_SVC_SERVER_VERSION);
d6e8d8
					preg_match('#V([\d.]+)#', $val, $match);
d6e8d8
					if ($match[1] < 2)
d6e8d8
					{
d6e8d8
						$error[] = $lang['INST_ERR_DB_NO_FIREBIRD'];
d6e8d8
					}
d6e8d8
					$db_info = @ibase_db_info($db->service_handle, $dbname, IBASE_STS_HDR_PAGES);
d6e8d8
d6e8d8
					preg_match('/^\\s*Page size\\s*(\\d+)/m', $db_info, $regs);
d6e8d8
					$page_size = intval($regs[1]);
d6e8d8
					if ($page_size < 8192)
d6e8d8
					{
d6e8d8
						$error[] = $lang['INST_ERR_DB_NO_FIREBIRD_PS'];
d6e8d8
					}
d6e8d8
				}
d6e8d8
				else
d6e8d8
				{
d6e8d8
					$sql = "SELECT *
d6e8d8
						FROM RDB$FUNCTIONS
d6e8d8
						WHERE RDB$SYSTEM_FLAG IS NULL
d6e8d8
							AND RDB$FUNCTION_NAME = 'CHAR_LENGTH'";
d6e8d8
					$result = $db->sql_query($sql);
d6e8d8
					$row = $db->sql_fetchrow($result);
d6e8d8
					$db->sql_freeresult($result);
d6e8d8
d6e8d8
					// if its a UDF, its too old
d6e8d8
					if ($row)
d6e8d8
					{
d6e8d8
						$error[] = $lang['INST_ERR_DB_NO_FIREBIRD'];
d6e8d8
					}
d6e8d8
					else
d6e8d8
					{
d6e8d8
						$sql = "SELECT FIRST 0 char_length('')
d6e8d8
							FROM RDB\$DATABASE";
d6e8d8
						$result = $db->sql_query($sql);
d6e8d8
						if (!$result) // This can only fail if char_length is not defined
d6e8d8
						{
d6e8d8
							$error[] = $lang['INST_ERR_DB_NO_FIREBIRD'];
d6e8d8
						}
d6e8d8
						$db->sql_freeresult($result);
d6e8d8
					}
d6e8d8
d6e8d8
					// Setup the stuff for our random table
d6e8d8
					$char_array = array_merge(range('A', 'Z'), range('0', '9'));
d6e8d8
					$char_len = mt_rand(7, 9);
d6e8d8
					$char_array_len = sizeof($char_array) - 1;
d6e8d8
d6e8d8
					$final = '';
d6e8d8
d6e8d8
					for ($i = 0; $i < $char_len; $i++)
d6e8d8
					{
d6e8d8
						$final .= $char_array[mt_rand(0, $char_array_len)];
d6e8d8
					}
d6e8d8
d6e8d8
					// Create some random table
d6e8d8
					$sql = 'CREATE TABLE ' . $final . " (
d6e8d8
						FIELD1 VARCHAR(255) CHARACTER SET UTF8 DEFAULT '' NOT NULL COLLATE UNICODE,
d6e8d8
						FIELD2 INTEGER DEFAULT 0 NOT NULL);";
d6e8d8
					$db->sql_query($sql);
d6e8d8
d6e8d8
					// Create an index that should fail if the page size is less than 8192
d6e8d8
					$sql = 'CREATE INDEX ' . $final . ' ON ' . $final . '(FIELD1, FIELD2);';
d6e8d8
					$db->sql_query($sql);
d6e8d8
d6e8d8
					if (ibase_errmsg() !== false)
d6e8d8
					{
d6e8d8
						$error[] = $lang['INST_ERR_DB_NO_FIREBIRD_PS'];
d6e8d8
					}
d6e8d8
					else
d6e8d8
					{
d6e8d8
						// Kill the old table
d6e8d8
						$db->sql_query('DROP TABLE ' . $final . ';');
d6e8d8
					}
d6e8d8
					unset($final);
d6e8d8
				}
d6e8d8
			break;
d6e8d8
			
d6e8d8
			case 'oracle':
d6e8d8
				if ($unicode_check)
d6e8d8
				{
d6e8d8
					$sql = "SELECT *
d6e8d8
						FROM NLS_DATABASE_PARAMETERS
d6e8d8
						WHERE PARAMETER = 'NLS_RDBMS_VERSION'
d6e8d8
							OR PARAMETER = 'NLS_CHARACTERSET'";
d6e8d8
					$result = $db->sql_query($sql);
d6e8d8
d6e8d8
					while ($row = $db->sql_fetchrow($result))
d6e8d8
					{
d6e8d8
						$stats[$row['parameter']] = $row['value'];
d6e8d8
					}
d6e8d8
					$db->sql_freeresult($result);
d6e8d8
d6e8d8
					if (version_compare($stats['NLS_RDBMS_VERSION'], '9.2', '<') && $stats['NLS_CHARACTERSET'] !== 'UTF8')
d6e8d8
					{
d6e8d8
						$error[] = $lang['INST_ERR_DB_NO_ORACLE'];
d6e8d8
					}
d6e8d8
				}
d6e8d8
			break;
d6e8d8
			
d6e8d8
			case 'postgres':
d6e8d8
				if ($unicode_check)
d6e8d8
				{
d6e8d8
					$sql = "SHOW server_encoding;";
d6e8d8
					$result = $db->sql_query($sql);
d6e8d8
					$row = $db->sql_fetchrow($result);
d6e8d8
					$db->sql_freeresult($result);
d6e8d8
d6e8d8
					if ($row['server_encoding'] !== 'UNICODE' && $row['server_encoding'] !== 'UTF8')
d6e8d8
					{
d6e8d8
						$error[] = $lang['INST_ERR_DB_NO_POSTGRES'];
d6e8d8
					}
d6e8d8
				}
d6e8d8
			break;
d6e8d8
		}
d6e8d8
d6e8d8
	}
d6e8d8
d6e8d8
	if ($error_connect && (!isset($error) || !sizeof($error)))
d6e8d8
	{
d6e8d8
		return true;
d6e8d8
	}
d6e8d8
	return false;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* remove_remarks will strip the sql comment lines out of an uploaded sql file
d6e8d8
*/
d6e8d8
function remove_remarks(&$sql)
d6e8d8
{
d6e8d8
	$sql = preg_replace('/\n{2,}/', "\n", preg_replace('/^#.*$/m', "\n", $sql));
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* split_sql_file will split an uploaded sql file into single sql statements.
d6e8d8
* Note: expects trim() to have already been run on $sql.
d6e8d8
*/
d6e8d8
function split_sql_file($sql, $delimiter)
d6e8d8
{
d6e8d8
	$sql = str_replace("\r" , '', $sql);
d6e8d8
	$data = preg_split('/' . preg_quote($delimiter, '/') . '$/m', $sql);
d6e8d8
d6e8d8
	$data = array_map('trim', $data);
d6e8d8
d6e8d8
	// The empty case
d6e8d8
	$end_data = end($data);
d6e8d8
d6e8d8
	if (empty($end_data))
d6e8d8
	{
d6e8d8
		unset($data[key($data)]);
d6e8d8
	}
d6e8d8
d6e8d8
	return $data;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* For replacing {L_*} strings with preg_replace_callback
d6e8d8
*/
d6e8d8
function adjust_language_keys_callback($matches)
d6e8d8
{
d6e8d8
	if (!empty($matches[1]))
d6e8d8
	{
d6e8d8
		global $lang, $db;
d6e8d8
d6e8d8
		return (!empty($lang[$matches[1]])) ? $db->sql_escape($lang[$matches[1]]) : $db->sql_escape($matches[1]);
d6e8d8
	}
d6e8d8
}
d6e8d8
d6e8d8
?>