mirror of
https://github.com/phpbb/phpbb.git
synced 2025-02-13 12:35:06 +01:00
Once more, this introduces language variables. git-svn-id: file:///svn/phpbb/trunk@7583 89ea8834-ac86-4346-8a33-228a782c2dd0
2134 lines
66 KiB
PHP
Executable File
2134 lines
66 KiB
PHP
Executable File
<?php
|
|
/**
|
|
*
|
|
* @package install
|
|
* @version $Id$
|
|
* @copyright (c) 2005 phpBB Group
|
|
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
|
|
*
|
|
*/
|
|
|
|
/**
|
|
*/
|
|
if (!defined('IN_INSTALL'))
|
|
{
|
|
// Someone has tried to access the file direct. This is not a good idea, so exit
|
|
exit;
|
|
}
|
|
|
|
if (!empty($setmodules))
|
|
{
|
|
// If phpBB is already installed we do not include this module
|
|
if (@file_exists($phpbb_root_path . 'config.' . $phpEx) && !file_exists($phpbb_root_path . 'cache/install_lock'))
|
|
{
|
|
include_once($phpbb_root_path . 'config.' . $phpEx);
|
|
|
|
if (defined('PHPBB_INSTALLED'))
|
|
{
|
|
return;
|
|
}
|
|
}
|
|
|
|
$module[] = array(
|
|
'module_type' => 'install',
|
|
'module_title' => 'INSTALL',
|
|
'module_filename' => substr(basename(__FILE__), 0, -strlen($phpEx)-1),
|
|
'module_order' => 10,
|
|
'module_subs' => '',
|
|
'module_stages' => array('INTRO', 'REQUIREMENTS', 'DATABASE', 'ADMINISTRATOR', 'CONFIG_FILE', 'ADVANCED', 'CREATE_TABLE', 'FINAL'),
|
|
'module_reqs' => ''
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Installation
|
|
* @package install
|
|
*/
|
|
class install_install extends module
|
|
{
|
|
function install_install(&$p_master)
|
|
{
|
|
$this->p_master = &$p_master;
|
|
}
|
|
|
|
function main($mode, $sub)
|
|
{
|
|
global $lang, $template, $language, $phpbb_root_path;
|
|
|
|
switch ($sub)
|
|
{
|
|
case 'intro' :
|
|
$this->page_title = $lang['SUB_INTRO'];
|
|
|
|
$template->assign_vars(array(
|
|
'TITLE' => $lang['INSTALL_INTRO'],
|
|
'BODY' => $lang['INSTALL_INTRO_BODY'],
|
|
'L_SUBMIT' => $lang['NEXT'],
|
|
'S_LANG_SELECT' => '<select id="language" name="language">' . $this->p_master->inst_language_select($language) . '</select>',
|
|
'U_ACTION' => $this->p_master->module_url . "?mode=$mode&sub=requirements&language=$language",
|
|
));
|
|
|
|
break;
|
|
|
|
case 'requirements' :
|
|
$this->check_server_requirements($mode, $sub);
|
|
|
|
break;
|
|
|
|
case 'database' :
|
|
$this->obtain_database_settings($mode, $sub);
|
|
|
|
break;
|
|
|
|
case 'administrator' :
|
|
$this->obtain_admin_settings($mode, $sub);
|
|
|
|
break;
|
|
|
|
case 'config_file' :
|
|
$this->create_config_file($mode, $sub);
|
|
|
|
break;
|
|
|
|
case 'advanced' :
|
|
$this->obtain_advanced_settings($mode, $sub);
|
|
|
|
break;
|
|
|
|
case 'create_table':
|
|
$this->load_schema($mode, $sub);
|
|
break;
|
|
|
|
case 'final' :
|
|
$this->add_modules($mode, $sub);
|
|
$this->add_language($mode, $sub);
|
|
$this->add_bots($mode, $sub);
|
|
$this->email_admin($mode, $sub);
|
|
|
|
// Remove the lock file
|
|
@unlink($phpbb_root_path . 'cache/install_lock');
|
|
|
|
break;
|
|
}
|
|
|
|
$this->tpl_name = 'install_install';
|
|
}
|
|
|
|
/**
|
|
* Checks that the server we are installing on meets the requirements for running phpBB
|
|
*/
|
|
function check_server_requirements($mode, $sub)
|
|
{
|
|
global $lang, $template, $phpbb_root_path, $phpEx, $language;
|
|
|
|
$this->page_title = $lang['STAGE_REQUIREMENTS'];
|
|
|
|
$template->assign_vars(array(
|
|
'TITLE' => $lang['REQUIREMENTS_TITLE'],
|
|
'BODY' => $lang['REQUIREMENTS_EXPLAIN'],
|
|
));
|
|
|
|
$passed = array('php' => false, 'db' => false, 'files' => false, 'pcre' => false, 'imagesize' => false,);
|
|
|
|
// Test for basic PHP settings
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['PHP_SETTINGS'],
|
|
'LEGEND_EXPLAIN' => $lang['PHP_SETTINGS_EXPLAIN'],
|
|
));
|
|
|
|
// Test the minimum PHP version
|
|
$php_version = PHP_VERSION;
|
|
|
|
if (version_compare($php_version, '4.3.3') < 0)
|
|
{
|
|
$result = '<b style="color:red">' . $lang['NO'] . '</b>';
|
|
}
|
|
else
|
|
{
|
|
$passed['php'] = true;
|
|
|
|
// We also give feedback on whether we're running in safe mode
|
|
$result = '<b style="color:green">' . $lang['YES'];
|
|
if (@ini_get('safe_mode') || strtolower(@ini_get('safe_mode')) == 'on')
|
|
{
|
|
$result .= ', ' . $lang['PHP_SAFE_MODE'];
|
|
}
|
|
$result .= '</b>';
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['PHP_VERSION_REQD'],
|
|
'RESULT' => $result,
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
|
|
// Check for register_globals being enabled
|
|
if (@ini_get('register_globals') == '1' || strtolower(@ini_get('register_globals')) == 'on')
|
|
{
|
|
$result = '<b style="color:red">' . $lang['NO'] . '</b>';
|
|
}
|
|
else
|
|
{
|
|
$result = '<b style="color:green">' . $lang['YES'] . '</b>';
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['PHP_REGISTER_GLOBALS'],
|
|
'TITLE_EXPLAIN' => $lang['PHP_REGISTER_GLOBALS_EXPLAIN'],
|
|
'RESULT' => $result,
|
|
|
|
'S_EXPLAIN' => true,
|
|
'S_LEGEND' => false,
|
|
));
|
|
|
|
|
|
// Check for url_fopen
|
|
if (@ini_get('allow_url_fopen') == '1' || strtolower(@ini_get('allow_url_fopen')) == 'on')
|
|
{
|
|
$result = '<b style="color:green">' . $lang['YES'] . '</b>';
|
|
}
|
|
else
|
|
{
|
|
$result = '<b style="color:red">' . $lang['NO'] . '</b>';
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['PHP_URL_FOPEN_SUPPORT'],
|
|
'TITLE_EXPLAIN' => $lang['PHP_URL_FOPEN_SUPPORT_EXPLAIN'],
|
|
'RESULT' => $result,
|
|
|
|
'S_EXPLAIN' => true,
|
|
'S_LEGEND' => false,
|
|
));
|
|
|
|
|
|
// Check for getimagesize
|
|
if (@function_exists('getimagesize'))
|
|
{
|
|
$passed['imagesize'] = true;
|
|
$result = '<b style="color:green">' . $lang['YES'] . '</b>';
|
|
}
|
|
else
|
|
{
|
|
$result = '<b style="color:red">' . $lang['NO'] . '</b>';
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['PHP_GETIMAGESIZE_SUPPORT'],
|
|
'TITLE_EXPLAIN' => $lang['PHP_GETIMAGESIZE_SUPPORT_EXPLAIN'],
|
|
'RESULT' => $result,
|
|
|
|
'S_EXPLAIN' => true,
|
|
'S_LEGEND' => false,
|
|
));
|
|
|
|
// Check for PCRE UTF-8 support
|
|
if (@preg_match('//u', ''))
|
|
{
|
|
$passed['pcre'] = true;
|
|
$result = '<b style="color:green">' . $lang['YES'] . '</b>';
|
|
}
|
|
else
|
|
{
|
|
$result = '<b style="color:red">' . $lang['NO'] . '</b>';
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['PCRE_UTF_SUPPORT'],
|
|
'TITLE_EXPLAIN' => $lang['PCRE_UTF_SUPPORT_EXPLAIN'],
|
|
'RESULT' => $result,
|
|
|
|
'S_EXPLAIN' => true,
|
|
'S_LEGEND' => false,
|
|
));
|
|
|
|
/**
|
|
* Better not enabling and adding to the loaded extensions due to the specific requirements needed
|
|
if (!@extension_loaded('mbstring'))
|
|
{
|
|
can_load_dll('mbstring');
|
|
}
|
|
*/
|
|
|
|
$passed['mbstring'] = true;
|
|
if (@extension_loaded('mbstring'))
|
|
{
|
|
// Test for available database modules
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['MBSTRING_CHECK'],
|
|
'LEGEND_EXPLAIN' => $lang['MBSTRING_CHECK_EXPLAIN'],
|
|
));
|
|
|
|
$checks = array(
|
|
array('func_overload', '&', MB_OVERLOAD_MAIL|MB_OVERLOAD_STRING),
|
|
array('encoding_translation', '!=', 0),
|
|
array('http_input', '!=', 'pass'),
|
|
array('http_output', '!=', 'pass')
|
|
);
|
|
|
|
foreach ($checks as $mb_checks)
|
|
{
|
|
$ini_val = ini_get('mbstring.' . $mb_checks[0]);
|
|
switch ($mb_checks[1])
|
|
{
|
|
case '&':
|
|
if (intval($ini_val) & $mb_checks[2])
|
|
{
|
|
$result = '<b style="color:red">' . $lang['NO'] . '</b>';
|
|
$passed['mbstring'] = false;
|
|
}
|
|
else
|
|
{
|
|
$result = '<b style="color:green">' . $lang['YES'] . '</b>';
|
|
}
|
|
break;
|
|
|
|
case '!=':
|
|
if ($ini_val != $mb_checks[2])
|
|
{
|
|
$result = '<b style="color:red">' . $lang['NO'] . '</b>';
|
|
$passed['mbstring'] = false;
|
|
}
|
|
else
|
|
{
|
|
$result = '<b style="color:green">' . $lang['YES'] . '</b>';
|
|
}
|
|
break;
|
|
}
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['MBSTRING_' . strtoupper($mb_checks[0])],
|
|
'TITLE_EXPLAIN' => $lang['MBSTRING_' . strtoupper($mb_checks[0]) . '_EXPLAIN'],
|
|
'RESULT' => $result,
|
|
|
|
'S_EXPLAIN' => true,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
}
|
|
|
|
// Test for available database modules
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['PHP_SUPPORTED_DB'],
|
|
'LEGEND_EXPLAIN' => $lang['PHP_SUPPORTED_DB_EXPLAIN'],
|
|
));
|
|
|
|
$available_dbms = get_available_dbms(false, true);
|
|
$passed['db'] = $available_dbms['ANY_DB_SUPPORT'];
|
|
unset($available_dbms['ANY_DB_SUPPORT']);
|
|
|
|
foreach ($available_dbms as $db_name => $db_ary)
|
|
{
|
|
if (!$db_ary['AVAILABLE'])
|
|
{
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['DLL_' . strtoupper($db_name)],
|
|
'RESULT' => '<span style="color:red">' . $lang['UNAVAILABLE'] . '</span>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
else
|
|
{
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['DLL_' . strtoupper($db_name)],
|
|
'RESULT' => '<b style="color:green">' . $lang['AVAILABLE'] . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
}
|
|
|
|
// Test for other modules
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['PHP_OPTIONAL_MODULE'],
|
|
'LEGEND_EXPLAIN' => $lang['PHP_OPTIONAL_MODULE_EXPLAIN'],
|
|
));
|
|
|
|
foreach ($this->php_dlls_other as $dll)
|
|
{
|
|
if (!@extension_loaded($dll))
|
|
{
|
|
if (!can_load_dll($dll))
|
|
{
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['DLL_' . strtoupper($dll)],
|
|
'RESULT' => '<b style="color:red">' . $lang['UNAVAILABLE'] . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
continue;
|
|
}
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['DLL_' . strtoupper($dll)],
|
|
'RESULT' => '<b style="color:green">' . $lang['AVAILABLE'] . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
|
|
// Can we find Imagemagick anywhere on the system?
|
|
$exe = (defined('PHP_OS') && strpos(strtolower(PHP_OS), 'win') === 0) ? '.exe' : '';
|
|
|
|
$magic_home = getenv('MAGICK_HOME');
|
|
$img_imagick = '';
|
|
if (empty($magic_home))
|
|
{
|
|
$locations = array('C:/WINDOWS/', 'C:/WINNT/', 'C:/WINDOWS/SYSTEM/', 'C:/WINNT/SYSTEM/', 'C:/WINDOWS/SYSTEM32/', 'C:/WINNT/SYSTEM32/', '/usr/bin/', '/usr/sbin/', '/usr/local/bin/', '/usr/local/sbin/', '/opt/', '/usr/imagemagick/', '/usr/bin/imagemagick/');
|
|
$path_locations = str_replace('\\', '/', (explode(($exe) ? ';' : ':', getenv('PATH'))));
|
|
|
|
$locations = array_merge($path_locations, $locations);
|
|
foreach ($locations as $location)
|
|
{
|
|
// The path might not end properly, fudge it
|
|
if (substr($location, -1, 1) !== '/')
|
|
{
|
|
$location .= '/';
|
|
}
|
|
|
|
if (@is_readable($location . 'mogrify' . $exe) && @filesize($location . 'mogrify' . $exe) > 3000)
|
|
{
|
|
$img_imagick = str_replace('\\', '/', $location);
|
|
continue;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$img_imagick = str_replace('\\', '/', $magic_home);
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['APP_MAGICK'],
|
|
'RESULT' => ($img_imagick) ? '<b style="color:green">' . $lang['AVAILABLE'] . ', ' . $img_imagick . '</b>' : '<b style="color:blue">' . $lang['NO_LOCATION'] . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
|
|
// Check permissions on files/directories we need access to
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['FILES_REQUIRED'],
|
|
'LEGEND_EXPLAIN' => $lang['FILES_REQUIRED_EXPLAIN'],
|
|
));
|
|
|
|
$directories = array('cache/', 'files/', 'store/');
|
|
|
|
umask(0);
|
|
|
|
$passed['files'] = true;
|
|
foreach ($directories as $dir)
|
|
{
|
|
$exists = $write = false;
|
|
|
|
// Try to create the directory if it does not exist
|
|
if (!file_exists($phpbb_root_path . $dir))
|
|
{
|
|
@mkdir($phpbb_root_path . $dir, 0777);
|
|
@chmod($phpbb_root_path . $dir, 0777);
|
|
}
|
|
|
|
// Now really check
|
|
if (file_exists($phpbb_root_path . $dir) && is_dir($phpbb_root_path . $dir))
|
|
{
|
|
if (!@is_writable($phpbb_root_path . $dir))
|
|
{
|
|
@chmod($phpbb_root_path . $dir, 0777);
|
|
}
|
|
$exists = true;
|
|
}
|
|
|
|
// Now check if it is writable by storing a simple file
|
|
$fp = @fopen($phpbb_root_path . $dir . 'test_lock', 'wb');
|
|
if ($fp !== false)
|
|
{
|
|
$write = true;
|
|
}
|
|
@fclose($fp);
|
|
|
|
@unlink($phpbb_root_path . $dir . 'test_lock');
|
|
|
|
$passed['files'] = ($exists && $write && $passed['files']) ? true : false;
|
|
|
|
$exists = ($exists) ? '<b style="color:green">' . $lang['FOUND'] . '</b>' : '<b style="color:red">' . $lang['NOT_FOUND'] . '</b>';
|
|
$write = ($write) ? ', <b style="color:green">' . $lang['WRITABLE'] . '</b>' : (($exists) ? ', <b style="color:red">' . $lang['UNWRITABLE'] . '</b>' : '');
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $dir,
|
|
'RESULT' => $exists . $write,
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
|
|
// Check permissions on files/directories it would be useful access to
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['FILES_OPTIONAL'],
|
|
'LEGEND_EXPLAIN' => $lang['FILES_OPTIONAL_EXPLAIN'],
|
|
));
|
|
|
|
$directories = array('config.'.$phpEx, 'images/avatars/upload/');
|
|
|
|
foreach ($directories as $dir)
|
|
{
|
|
$write = $exists = true;
|
|
if (file_exists($phpbb_root_path . $dir))
|
|
{
|
|
if (!@is_writable($phpbb_root_path . $dir))
|
|
{
|
|
$write = false;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$write = $exists = false;
|
|
}
|
|
|
|
$exists_str = ($exists) ? '<b style="color:green">' . $lang['FOUND'] . '</b>' : '<b style="color:red">' . $lang['NOT_FOUND'] . '</b>';
|
|
$write_str = ($write) ? ', <b style="color:green">' . $lang['WRITABLE'] . '</b>' : (($exists) ? ', <b style="color:red">' . $lang['UNWRITABLE'] . '</b>' : '');
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $dir,
|
|
'RESULT' => $exists_str . $write_str,
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
|
|
// And finally where do we want to go next (well today is taken isn't it :P)
|
|
$s_hidden_fields = ($img_imagick) ? '<input type="hidden" name="img_imagick" value="' . addslashes($img_imagick) . '" />' : '';
|
|
|
|
$url = (!in_array(false, $passed)) ? $this->p_master->module_url . "?mode=$mode&sub=database&language=$language" : $this->p_master->module_url . "?mode=$mode&sub=requirements&language=$language ";
|
|
$submit = (!in_array(false, $passed)) ? $lang['INSTALL_START'] : $lang['INSTALL_TEST'];
|
|
|
|
|
|
$template->assign_vars(array(
|
|
'L_SUBMIT' => $submit,
|
|
'S_HIDDEN' => $s_hidden_fields,
|
|
'U_ACTION' => $url,
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Obtain the information required to connect to the database
|
|
*/
|
|
function obtain_database_settings($mode, $sub)
|
|
{
|
|
global $lang, $template, $phpEx;
|
|
|
|
$this->page_title = $lang['STAGE_DATABASE'];
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
$connect_test = false;
|
|
$error = array();
|
|
$available_dbms = get_available_dbms(false, true);
|
|
|
|
// Has the user opted to test the connection?
|
|
if (isset($_POST['testdb']))
|
|
{
|
|
if (!isset($available_dbms[$dbms]) || !$available_dbms[$dbms]['AVAILABLE'])
|
|
{
|
|
$error['db'][] = $lang['INST_ERR_NO_DB'];
|
|
$connect_test = false;
|
|
}
|
|
else
|
|
{
|
|
$dbpasswd = htmlspecialchars_decode($dbpasswd);
|
|
$connect_test = connect_check_db(true, $error, $available_dbms[$dbms], $table_prefix, $dbhost, $dbuser, $dbpasswd, $dbname, $dbport);
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['DB_CONNECTION'],
|
|
'LEGEND_EXPLAIN' => false,
|
|
));
|
|
|
|
if ($connect_test)
|
|
{
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['DB_TEST'],
|
|
'RESULT' => '<b style="color:green">' . $lang['SUCCESSFUL_CONNECT'] . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
else
|
|
{
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['DB_TEST'],
|
|
'RESULT' => '<b style="color:red">' . implode('<br />', $error) . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
}
|
|
|
|
if (!$connect_test)
|
|
{
|
|
// Update the list of available DBMS modules to only contain those which can be used
|
|
$available_dbms_temp = array();
|
|
foreach ($available_dbms as $type => $dbms_ary)
|
|
{
|
|
if (!$dbms_ary['AVAILABLE'])
|
|
{
|
|
continue;
|
|
}
|
|
|
|
$available_dbms_temp[$type] = $dbms_ary;
|
|
}
|
|
|
|
$available_dbms = &$available_dbms_temp;
|
|
|
|
// And now for the main part of this page
|
|
$table_prefix = (!empty($table_prefix) ? $table_prefix : 'phpbb_');
|
|
|
|
foreach ($this->db_config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars) && strpos($config_key, 'legend') === false)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if (strpos($config_key, 'legend') !== false)
|
|
{
|
|
$template->assign_block_vars('options', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang[$vars])
|
|
);
|
|
|
|
continue;
|
|
}
|
|
|
|
$options = isset($vars['options']) ? $vars['options'] : '';
|
|
|
|
$template->assign_block_vars('options', array(
|
|
'KEY' => $config_key,
|
|
'TITLE' => $lang[$vars['lang']],
|
|
'S_EXPLAIN' => $vars['explain'],
|
|
'S_LEGEND' => false,
|
|
'TITLE_EXPLAIN' => ($vars['explain']) ? $lang[$vars['lang'] . '_EXPLAIN'] : '',
|
|
'CONTENT' => $this->p_master->input_field($config_key, $vars['type'], $$config_key, $options),
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
// And finally where do we want to go next (well today is taken isn't it :P)
|
|
$s_hidden_fields = ($img_imagick) ? '<input type="hidden" name="img_imagick" value="' . addslashes($img_imagick) . '" />' : '';
|
|
$s_hidden_fields .= '<input type="hidden" name="language" value="' . $language . '" />';
|
|
if ($connect_test)
|
|
{
|
|
foreach ($this->db_config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars))
|
|
{
|
|
continue;
|
|
}
|
|
$s_hidden_fields .= '<input type="hidden" name="' . $config_key . '" value="' . $$config_key . '" />';
|
|
}
|
|
}
|
|
|
|
$url = ($connect_test) ? $this->p_master->module_url . "?mode=$mode&sub=administrator" : $this->p_master->module_url . "?mode=$mode&sub=database";
|
|
$s_hidden_fields .= ($connect_test) ? '' : '<input type="hidden" name="testdb" value="true" />';
|
|
|
|
$submit = $lang['NEXT_STEP'];
|
|
|
|
$template->assign_vars(array(
|
|
'L_SUBMIT' => $submit,
|
|
'S_HIDDEN' => $s_hidden_fields,
|
|
'U_ACTION' => $url,
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Obtain the administrator's name, password and email address
|
|
*/
|
|
function obtain_admin_settings($mode, $sub)
|
|
{
|
|
global $lang, $template, $phpEx;
|
|
|
|
$this->page_title = $lang['STAGE_ADMINISTRATOR'];
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
if ($dbms == '')
|
|
{
|
|
// Someone's been silly and tried calling this page direct
|
|
// So we send them back to the start to do it again properly
|
|
$this->p_master->redirect("index.$phpEx?mode=install");
|
|
}
|
|
|
|
$s_hidden_fields = ($img_imagick) ? '<input type="hidden" name="img_imagick" value="' . addslashes($img_imagick) . '" />' : '';
|
|
$passed = false;
|
|
|
|
$default_lang = ($default_lang !== '') ? $default_lang : $language;
|
|
|
|
$board_email1 = strtolower($board_email1);
|
|
$board_email2 = strtolower($board_email2);
|
|
|
|
if (isset($_POST['check']))
|
|
{
|
|
$error = array();
|
|
|
|
// Check the entered email address and password
|
|
if ($admin_name == '' || $admin_pass1 == '' || $admin_pass2 == '' || $board_email1 == '' || $board_email2 == '')
|
|
{
|
|
$error[] = $lang['INST_ERR_MISSING_DATA'];
|
|
}
|
|
|
|
if ($admin_pass1 != $admin_pass2 && $admin_pass1 != '')
|
|
{
|
|
$error[] = $lang['INST_ERR_PASSWORD_MISMATCH'];
|
|
}
|
|
|
|
// Test against the default username rules
|
|
if ($admin_name != '' && utf8_strlen($admin_name) < 3)
|
|
{
|
|
$error[] = $lang['INST_ERR_USER_TOO_SHORT'];
|
|
}
|
|
|
|
if ($admin_name != '' && utf8_strlen($admin_name) > 20)
|
|
{
|
|
$error[] = $lang['INST_ERR_USER_TOO_LONG'];
|
|
}
|
|
|
|
// Test against the default password rules
|
|
if ($admin_pass1 != '' && utf8_strlen($admin_pass1) < 6)
|
|
{
|
|
$error[] = $lang['INST_ERR_PASSWORD_TOO_SHORT'];
|
|
}
|
|
|
|
if ($admin_pass1 != '' && utf8_strlen($admin_pass1) > 30)
|
|
{
|
|
$error[] = $lang['INST_ERR_PASSWORD_TOO_LONG'];
|
|
}
|
|
|
|
if ($board_email1 != $board_email2 && $board_email1 != '')
|
|
{
|
|
$error[] = $lang['INST_ERR_EMAIL_MISMATCH'];
|
|
}
|
|
|
|
if ($board_email1 != '' && !preg_match('/^' . get_preg_expression('email') . '$/i', $board_email1))
|
|
{
|
|
$error[] = $lang['INST_ERR_EMAIL_INVALID'];
|
|
}
|
|
|
|
$template->assign_block_vars('checks', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang['STAGE_ADMINISTRATOR'],
|
|
'LEGEND_EXPLAIN' => false,
|
|
));
|
|
|
|
if (!sizeof($error))
|
|
{
|
|
$passed = true;
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['ADMIN_TEST'],
|
|
'RESULT' => '<b style="color:green">' . $lang['TESTS_PASSED'] . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
else
|
|
{
|
|
$template->assign_block_vars('checks', array(
|
|
'TITLE' => $lang['ADMIN_TEST'],
|
|
'RESULT' => '<b style="color:red">' . implode('<br />', $error) . '</b>',
|
|
|
|
'S_EXPLAIN' => false,
|
|
'S_LEGEND' => false,
|
|
));
|
|
}
|
|
}
|
|
|
|
if (!$passed)
|
|
{
|
|
foreach ($this->admin_config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars) && strpos($config_key, 'legend') === false)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if (strpos($config_key, 'legend') !== false)
|
|
{
|
|
$template->assign_block_vars('options', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang[$vars])
|
|
);
|
|
|
|
continue;
|
|
}
|
|
|
|
$options = isset($vars['options']) ? $vars['options'] : '';
|
|
|
|
$template->assign_block_vars('options', array(
|
|
'KEY' => $config_key,
|
|
'TITLE' => $lang[$vars['lang']],
|
|
'S_EXPLAIN' => $vars['explain'],
|
|
'S_LEGEND' => false,
|
|
'TITLE_EXPLAIN' => ($vars['explain']) ? $lang[$vars['lang'] . '_EXPLAIN'] : '',
|
|
'CONTENT' => $this->p_master->input_field($config_key, $vars['type'], $$config_key, $options),
|
|
)
|
|
);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
foreach ($this->admin_config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars))
|
|
{
|
|
continue;
|
|
}
|
|
$s_hidden_fields .= '<input type="hidden" name="' . $config_key . '" value="' . $$config_key . '" />';
|
|
}
|
|
}
|
|
|
|
$s_hidden_fields .= ($img_imagick) ? '<input type="hidden" name="img_imagick" value="' . addslashes($img_imagick) . '" />' : '';
|
|
$s_hidden_fields .= '<input type="hidden" name="language" value="' . $language . '" />';
|
|
|
|
foreach ($this->db_config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars))
|
|
{
|
|
continue;
|
|
}
|
|
$s_hidden_fields .= '<input type="hidden" name="' . $config_key . '" value="' . $$config_key . '" />';
|
|
}
|
|
|
|
$submit = $lang['NEXT_STEP'];
|
|
|
|
$url = ($passed) ? $this->p_master->module_url . "?mode=$mode&sub=config_file" : $this->p_master->module_url . "?mode=$mode&sub=administrator";
|
|
$s_hidden_fields .= ($passed) ? '' : '<input type="hidden" name="check" value="true" />';
|
|
|
|
$template->assign_vars(array(
|
|
'L_SUBMIT' => $submit,
|
|
'S_HIDDEN' => $s_hidden_fields,
|
|
'U_ACTION' => $url,
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Writes the config file to disk, or if unable to do so offers alternative methods
|
|
*/
|
|
function create_config_file($mode, $sub)
|
|
{
|
|
global $lang, $template, $phpbb_root_path, $phpEx;
|
|
|
|
$this->page_title = $lang['STAGE_CONFIG_FILE'];
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
if ($dbms == '')
|
|
{
|
|
// Someone's been silly and tried calling this page direct
|
|
// So we send them back to the start to do it again properly
|
|
$this->p_master->redirect("index.$phpEx?mode=install");
|
|
}
|
|
|
|
$s_hidden_fields = ($img_imagick) ? '<input type="hidden" name="img_imagick" value="' . addslashes($img_imagick) . '" />' : '';
|
|
$s_hidden_fields .= '<input type="hidden" name="language" value="' . $language . '" />';
|
|
$written = false;
|
|
|
|
// Create a list of any PHP modules we wish to have loaded
|
|
$load_extensions = array();
|
|
$available_dbms = get_available_dbms($dbms);
|
|
$check_exts = array_merge(array($available_dbms[$dbms]['MODULE']), $this->php_dlls_other);
|
|
|
|
$suffix = (defined('PHP_OS') && strpos(strtolower(PHP_OS), 'win') === 0) ? 'dll' : 'so';
|
|
|
|
foreach ($check_exts as $dll)
|
|
{
|
|
if (!@extension_loaded($dll))
|
|
{
|
|
if (!can_load_dll($dll))
|
|
{
|
|
continue;
|
|
}
|
|
|
|
$load_extensions[] = "$dll.$suffix";
|
|
}
|
|
}
|
|
|
|
// Create a lock file to indicate that there is an install in progress
|
|
$fp = @fopen($phpbb_root_path . 'cache/install_lock', 'wb');
|
|
if ($fp === false)
|
|
{
|
|
// We were unable to create the lock file - abort
|
|
$this->p_master->error($lang['UNABLE_WRITE_LOCK'], __LINE__, __FILE__);
|
|
}
|
|
@fclose($fp);
|
|
|
|
$dbpasswd = htmlspecialchars_decode($dbpasswd);
|
|
$load_extensions = implode(',', $load_extensions);
|
|
|
|
// Time to convert the data provided into a config file
|
|
$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 .= "\$dbms = '" . $available_dbms[$dbms]['DRIVER'] . "';\n";
|
|
$config_data .= "\$dbhost = '$dbhost';\n";
|
|
$config_data .= "\$dbport = '$dbport';\n";
|
|
$config_data .= "\$dbname = '$dbname';\n";
|
|
$config_data .= "\$dbuser = '$dbuser';\n";
|
|
$config_data .= "\$dbpasswd = '$dbpasswd';\n\n";
|
|
$config_data .= "\$table_prefix = '$table_prefix';\n";
|
|
// $config_data .= "\$acm_type = '" . (($acm_type) ? $acm_type : 'file') . "';\n";
|
|
$config_data .= "\$acm_type = 'file';\n";
|
|
$config_data .= "\$load_extensions = '$load_extensions';\n\n";
|
|
$config_data .= "@define('PHPBB_INSTALLED', true);\n";
|
|
$config_data .= "@define('DEBUG', true);\n"; // @todo Comment out when final
|
|
$config_data .= "// @define('DEBUG_EXTRA', true);\n";
|
|
$config_data .= '?' . '>'; // Done this to prevent highlighting editors getting confused!
|
|
|
|
// Attempt to write out the config file directly. If it works, this is the easiest way to do it ...
|
|
if ((file_exists($phpbb_root_path . 'config.' . $phpEx) && is_writable($phpbb_root_path . 'config.' . $phpEx)) || is_writable($phpbb_root_path))
|
|
{
|
|
// Assume it will work ... if nothing goes wrong below
|
|
$written = true;
|
|
|
|
if (!($fp = @fopen($phpbb_root_path . 'config.'.$phpEx, 'w')))
|
|
{
|
|
// Something went wrong ... so let's try another method
|
|
$written = false;
|
|
}
|
|
|
|
if (!(@fwrite($fp, $config_data)))
|
|
{
|
|
// Something went wrong ... so let's try another method
|
|
$written = false;
|
|
}
|
|
|
|
@fclose($fp);
|
|
}
|
|
|
|
if (isset($_POST['dldone']))
|
|
{
|
|
// Do a basic check to make sure that the file has been uploaded
|
|
// Note that all we check is that the file has _something_ in it
|
|
// We don't compare the contents exactly - if they can't upload
|
|
// a single file correctly, it's likely they will have other problems....
|
|
if (filesize($phpbb_root_path . 'config.'.$phpEx) > 10)
|
|
{
|
|
$written = true;
|
|
}
|
|
}
|
|
|
|
$config_options = array_merge($this->db_config_options, $this->admin_config_options);
|
|
|
|
foreach ($config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars))
|
|
{
|
|
continue;
|
|
}
|
|
$s_hidden_fields .= '<input type="hidden" name="' . $config_key . '" value="' . $$config_key . '" />';
|
|
}
|
|
|
|
if (!$written)
|
|
{
|
|
// OK, so it didn't work let's try the alternatives
|
|
|
|
if (isset($_POST['dlconfig']))
|
|
{
|
|
// They want a copy of the file to download, so send the relevant headers and dump out the data
|
|
header("Content-Type: text/x-delimtext; name=\"config.$phpEx\"");
|
|
header("Content-disposition: attachment; filename=config.$phpEx");
|
|
echo $config_data;
|
|
exit;
|
|
}
|
|
|
|
// The option to download the config file is always available, so output it here
|
|
$template->assign_vars(array(
|
|
'BODY' => $lang['CONFIG_FILE_UNABLE_WRITE'],
|
|
'L_DL_CONFIG' => $lang['DL_CONFIG'],
|
|
'L_DL_CONFIG_EXPLAIN' => $lang['DL_CONFIG_EXPLAIN'],
|
|
'L_DL_DONE' => $lang['DONE'],
|
|
'L_DL_DOWNLOAD' => $lang['DL_DOWNLOAD'],
|
|
'S_HIDDEN' => $s_hidden_fields,
|
|
'S_SHOW_DOWNLOAD' => true,
|
|
'U_ACTION' => $this->p_master->module_url . "?mode=$mode&sub=config_file",
|
|
));
|
|
return;
|
|
}
|
|
else
|
|
{
|
|
$template->assign_vars(array(
|
|
'BODY' => $lang['CONFIG_FILE_WRITTEN'],
|
|
'L_SUBMIT' => $lang['NEXT_STEP'],
|
|
'S_HIDDEN' => $s_hidden_fields,
|
|
'U_ACTION' => $this->p_master->module_url . "?mode=$mode&sub=advanced",
|
|
));
|
|
return;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Provide an opportunity to customise some advanced settings during the install
|
|
* in case it is necessary for them to be set to access later
|
|
*/
|
|
function obtain_advanced_settings($mode, $sub)
|
|
{
|
|
global $lang, $template, $phpEx;
|
|
|
|
$this->page_title = $lang['STAGE_ADVANCED'];
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
if ($dbms == '')
|
|
{
|
|
// Someone's been silly and tried calling this page direct
|
|
// So we send them back to the start to do it again properly
|
|
$this->p_master->redirect("index.$phpEx?mode=install");
|
|
}
|
|
|
|
$s_hidden_fields = ($img_imagick) ? '<input type="hidden" name="img_imagick" value="' . addslashes($img_imagick) . '" />' : '';
|
|
$s_hidden_fields .= '<input type="hidden" name="language" value="' . $language . '" />';
|
|
|
|
$email_enable = ($email_enable !== '') ? $email_enable : true;
|
|
$server_name = ($server_name !== '') ? $server_name : ((!empty($_SERVER['SERVER_NAME'])) ? $_SERVER['SERVER_NAME'] : getenv('SERVER_NAME'));
|
|
$server_port = ($server_port !== '') ? $server_port : ((!empty($_SERVER['SERVER_PORT'])) ? (int) $_SERVER['SERVER_PORT'] : (int) getenv('SERVER_PORT'));
|
|
$server_protocol = ($server_protocol !== '') ? $server_protocol : ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') ? 'https://' : 'http://');
|
|
$cookie_secure = ($cookie_secure !== '') ? $cookie_secure : ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') ? true : false);
|
|
|
|
if ($script_path === '')
|
|
{
|
|
$name = (!empty($_SERVER['PHP_SELF'])) ? $_SERVER['PHP_SELF'] : getenv('PHP_SELF');
|
|
if (!$name)
|
|
{
|
|
$name = (!empty($_SERVER['REQUEST_URI'])) ? $_SERVER['REQUEST_URI'] : getenv('REQUEST_URI');
|
|
}
|
|
|
|
// Replace backslashes and doubled slashes (could happen on some proxy setups)
|
|
$name = str_replace(array('\\', '//', '/install'), '/', $name);
|
|
$script_path = trim(dirname($name));
|
|
}
|
|
|
|
foreach ($this->advanced_config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars) && strpos($config_key, 'legend') === false)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if (strpos($config_key, 'legend') !== false)
|
|
{
|
|
$template->assign_block_vars('options', array(
|
|
'S_LEGEND' => true,
|
|
'LEGEND' => $lang[$vars])
|
|
);
|
|
|
|
continue;
|
|
}
|
|
|
|
$options = isset($vars['options']) ? $vars['options'] : '';
|
|
|
|
$template->assign_block_vars('options', array(
|
|
'KEY' => $config_key,
|
|
'TITLE' => $lang[$vars['lang']],
|
|
'S_EXPLAIN' => $vars['explain'],
|
|
'S_LEGEND' => false,
|
|
'TITLE_EXPLAIN' => ($vars['explain']) ? $lang[$vars['lang'] . '_EXPLAIN'] : '',
|
|
'CONTENT' => $this->p_master->input_field($config_key, $vars['type'], $$config_key, $options),
|
|
)
|
|
);
|
|
}
|
|
|
|
$config_options = array_merge($this->db_config_options, $this->admin_config_options);
|
|
foreach ($config_options as $config_key => $vars)
|
|
{
|
|
if (!is_array($vars))
|
|
{
|
|
continue;
|
|
}
|
|
$s_hidden_fields .= '<input type="hidden" name="' . $config_key . '" value="' . $$config_key . '" />';
|
|
}
|
|
|
|
$submit = $lang['NEXT_STEP'];
|
|
|
|
$url = $this->p_master->module_url . "?mode=$mode&sub=create_table";
|
|
|
|
$template->assign_vars(array(
|
|
'BODY' => $lang['STAGE_ADVANCED_EXPLAIN'],
|
|
'L_SUBMIT' => $submit,
|
|
'S_HIDDEN' => $s_hidden_fields,
|
|
'U_ACTION' => $url,
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Load the contents of the schema into the database and then alter it based on what has been input during the installation
|
|
*/
|
|
function load_schema($mode, $sub)
|
|
{
|
|
global $db, $lang, $template, $phpbb_root_path, $phpEx;
|
|
|
|
$this->page_title = $lang['STAGE_CREATE_TABLE'];
|
|
$s_hidden_fields = '';
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
if ($dbms == '')
|
|
{
|
|
// Someone's been silly and tried calling this page direct
|
|
// So we send them back to the start to do it again properly
|
|
$this->p_master->redirect("index.$phpEx?mode=install");
|
|
}
|
|
|
|
$cookie_domain = ($server_name != '') ? $server_name : (!empty($_SERVER['SERVER_NAME'])) ? $_SERVER['SERVER_NAME'] : getenv('SERVER_NAME');
|
|
|
|
// Try to come up with the best solution for cookie domain...
|
|
if (strpos($cookie_domain, 'www.') === 0)
|
|
{
|
|
$cookie_domain = str_replace('www.', '.', $cookie_domain);
|
|
}
|
|
|
|
// If we get here and the extension isn't loaded it should be safe to just go ahead and load it
|
|
$available_dbms = get_available_dbms($dbms);
|
|
|
|
$dbpasswd = htmlspecialchars_decode($dbpasswd);
|
|
|
|
// Load the appropriate database class if not already loaded
|
|
include($phpbb_root_path . 'includes/db/' . $available_dbms[$dbms]['DRIVER'] . '.' . $phpEx);
|
|
|
|
// Instantiate the database
|
|
$sql_db = 'dbal_' . $available_dbms[$dbms]['DRIVER'];
|
|
$db = new $sql_db();
|
|
$db->sql_connect($dbhost, $dbuser, $dbpasswd, $dbname, $dbport, false, false);
|
|
|
|
// NOTE: trigger_error does not work here.
|
|
$db->sql_return_on_error(true);
|
|
|
|
// If mysql is chosen, we need to adjust the schema filename slightly to reflect the correct version. ;)
|
|
if ($dbms == 'mysql')
|
|
{
|
|
if (version_compare($db->mysql_version, '4.1.3', '>='))
|
|
{
|
|
$available_dbms[$dbms]['SCHEMA'] .= '_41';
|
|
}
|
|
else
|
|
{
|
|
$available_dbms[$dbms]['SCHEMA'] .= '_40';
|
|
}
|
|
}
|
|
|
|
// Ok we have the db info go ahead and read in the relevant schema
|
|
// and work on building the table
|
|
$dbms_schema = 'schemas/' . $available_dbms[$dbms]['SCHEMA'] . '_schema.sql';
|
|
|
|
// How should we treat this schema?
|
|
$remove_remarks = $available_dbms[$dbms]['COMMENTS'];
|
|
$delimiter = $available_dbms[$dbms]['DELIM'];
|
|
|
|
$sql_query = @file_get_contents($dbms_schema);
|
|
|
|
$sql_query = preg_replace('#phpbb_#i', $table_prefix, $sql_query);
|
|
|
|
$remove_remarks($sql_query);
|
|
|
|
$sql_query = split_sql_file($sql_query, $delimiter);
|
|
|
|
foreach ($sql_query as $sql)
|
|
{
|
|
//$sql = trim(str_replace('|', ';', $sql));
|
|
if (!$db->sql_query($sql))
|
|
{
|
|
$error = $db->sql_error();
|
|
$this->p_master->db_error($error['message'], $sql, __LINE__, __FILE__);
|
|
}
|
|
}
|
|
unset($sql_query);
|
|
|
|
// Ok tables have been built, let's fill in the basic information
|
|
$sql_query = file_get_contents('schemas/schema_data.sql');
|
|
|
|
// Deal with any special comments
|
|
switch ($dbms)
|
|
{
|
|
case 'mssql':
|
|
case 'mssql_odbc':
|
|
$sql_query = preg_replace('#\# MSSQL IDENTITY (phpbb_[a-z_]+) (ON|OFF) \##s', 'SET IDENTITY_INSERT \1 \2;', $sql_query);
|
|
break;
|
|
|
|
case 'postgres':
|
|
$sql_query = preg_replace('#\# POSTGRES (BEGIN|COMMIT) \##s', '\1; ', $sql_query);
|
|
break;
|
|
}
|
|
|
|
$sql_query = preg_replace('#phpbb_#i', $table_prefix, $sql_query);
|
|
|
|
// Since there is only one schema file we know the comment style and are able to remove it directly with remove_remarks
|
|
remove_remarks($sql_query);
|
|
$sql_query = split_sql_file($sql_query, ';');
|
|
|
|
foreach ($sql_query as $sql)
|
|
{
|
|
//$sql = trim(str_replace('|', ';', $sql));
|
|
if (!$db->sql_query($sql))
|
|
{
|
|
$error = $db->sql_error();
|
|
$this->p_master->db_error($error['message'], $sql, __LINE__, __FILE__);
|
|
}
|
|
}
|
|
unset($sql_query);
|
|
|
|
$current_time = time();
|
|
|
|
$user_ip = (!empty($_SERVER['REMOTE_ADDR'])) ? htmlspecialchars($_SERVER['REMOTE_ADDR']) : '';
|
|
|
|
if ($script_path !== '/')
|
|
{
|
|
// Adjust destination path (no trailing slash)
|
|
if (substr($script_path, -1) == '/')
|
|
{
|
|
$script_path = substr($script_path, 0, -1);
|
|
}
|
|
|
|
$script_path = str_replace(array('../', './'), '', $script_path);
|
|
|
|
if ($script_path[0] != '/')
|
|
{
|
|
$script_path = '/' . $script_path;
|
|
}
|
|
}
|
|
|
|
// Set default config and post data, this applies to all DB's
|
|
$sql_ary = array(
|
|
'INSERT INTO ' . $table_prefix . "config (config_name, config_value)
|
|
VALUES ('board_startdate', '$current_time')",
|
|
|
|
'INSERT INTO ' . $table_prefix . "config (config_name, config_value)
|
|
VALUES ('default_lang', '" . $db->sql_escape($default_lang) . "')",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($img_imagick) . "'
|
|
WHERE config_name = 'img_imagick'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($server_name) . "'
|
|
WHERE config_name = 'server_name'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($server_port) . "'
|
|
WHERE config_name = 'server_port'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($board_email1) . "'
|
|
WHERE config_name = 'board_email'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($board_email1) . "'
|
|
WHERE config_name = 'board_contact'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($cookie_domain) . "'
|
|
WHERE config_name = 'cookie_domain'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($lang['default_dateformat']) . "'
|
|
WHERE config_name = 'default_dateformat'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($email_enable) . "'
|
|
WHERE config_name = 'email_enable'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($smtp_delivery) . "'
|
|
WHERE config_name = 'smtp_delivery'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($smtp_host) . "'
|
|
WHERE config_name = 'smtp_host'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($smtp_auth) . "'
|
|
WHERE config_name = 'smtp_auth_method'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($smtp_user) . "'
|
|
WHERE config_name = 'smtp_username'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($smtp_pass) . "'
|
|
WHERE config_name = 'smtp_password'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($cookie_secure) . "'
|
|
WHERE config_name = 'cookie_secure'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($force_server_vars) . "'
|
|
WHERE config_name = 'force_server_vars'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($script_path) . "'
|
|
WHERE config_name = 'script_path'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($server_protocol) . "'
|
|
WHERE config_name = 'server_protocol'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($admin_name) . "'
|
|
WHERE config_name = 'newest_username'",
|
|
|
|
'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . md5(mt_rand()) . "'
|
|
WHERE config_name = 'avatar_salt'",
|
|
|
|
'UPDATE ' . $table_prefix . "users
|
|
SET username = '" . $db->sql_escape($admin_name) . "', user_password='" . $db->sql_escape(md5($admin_pass1)) . "', user_ip = '" . $db->sql_escape($user_ip) . "', user_lang = '" . $db->sql_escape($default_lang) . "', user_email='" . $db->sql_escape($board_email1) . "', user_dateformat='" . $db->sql_escape($lang['default_dateformat']) . "', user_email_hash = " . (crc32($board_email1) . strlen($board_email1)) . ", username_clean = '" . $db->sql_escape(utf8_clean_string($admin_name)) . "'
|
|
WHERE username = 'Admin'",
|
|
|
|
'UPDATE ' . $table_prefix . "moderator_cache
|
|
SET username = '" . $db->sql_escape($admin_name) . "'
|
|
WHERE username = 'Admin'",
|
|
|
|
'UPDATE ' . $table_prefix . "forums
|
|
SET forum_last_poster_name = '" . $db->sql_escape($admin_name) . "'
|
|
WHERE forum_last_poster_name = 'Admin'",
|
|
|
|
'UPDATE ' . $table_prefix . "topics
|
|
SET topic_first_poster_name = '" . $db->sql_escape($admin_name) . "', topic_last_poster_name = '" . $db->sql_escape($admin_name) . "'
|
|
WHERE topic_first_poster_name = 'Admin'
|
|
OR topic_last_poster_name = 'Admin'",
|
|
|
|
'UPDATE ' . $table_prefix . "users
|
|
SET user_regdate = $current_time",
|
|
|
|
'UPDATE ' . $table_prefix . "posts
|
|
SET post_time = $current_time, poster_ip = '" . $db->sql_escape($user_ip) . "'",
|
|
|
|
'UPDATE ' . $table_prefix . "topics
|
|
SET topic_time = $current_time, topic_last_post_time = $current_time",
|
|
|
|
'UPDATE ' . $table_prefix . "forums
|
|
SET forum_last_post_time = $current_time",
|
|
);
|
|
|
|
if (@extension_loaded('gd') || can_load_dll('gd'))
|
|
{
|
|
$sql_ary[] = 'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '1'
|
|
WHERE config_name = 'captcha_gd'";
|
|
}
|
|
|
|
// We set a (semi-)unique cookie name to bypass login issues related to the cookie name.
|
|
$cookie_name = 'phpbb3_';
|
|
$cookie_name .= strtolower(gen_rand_string(5));
|
|
|
|
$sql_ary[] = 'UPDATE ' . $table_prefix . "config
|
|
SET config_value = '" . $db->sql_escape($cookie_name) . "'
|
|
WHERE config_name = 'cookie_name'";
|
|
|
|
foreach ($sql_ary as $sql)
|
|
{
|
|
//$sql = trim(str_replace('|', ';', $sql));
|
|
|
|
if (!$db->sql_query($sql))
|
|
{
|
|
$error = $db->sql_error();
|
|
$this->p_master->db_error($error['message'], $sql, __LINE__, __FILE__);
|
|
}
|
|
}
|
|
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$s_hidden_fields .= '<input type="hidden" name="' . $var . '" value="' . $$var . '" />';
|
|
}
|
|
|
|
$submit = $lang['NEXT_STEP'];
|
|
|
|
$url = $this->p_master->module_url . "?mode=$mode&sub=final";
|
|
|
|
$template->assign_vars(array(
|
|
'BODY' => $lang['STAGE_CREATE_TABLE_EXPLAIN'],
|
|
'L_SUBMIT' => $submit,
|
|
'S_HIDDEN' => $s_hidden_fields,
|
|
'U_ACTION' => $url,
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Populate the module tables
|
|
*/
|
|
function add_modules($mode, $sub)
|
|
{
|
|
global $db, $lang, $phpbb_root_path, $phpEx;
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
$dbpasswd = htmlspecialchars_decode($dbpasswd);
|
|
|
|
// If we get here and the extension isn't loaded it should be safe to just go ahead and load it
|
|
$available_dbms = get_available_dbms($dbms);
|
|
|
|
// Load the appropriate database class if not already loaded
|
|
include($phpbb_root_path . 'includes/db/' . $available_dbms[$dbms]['DRIVER'] . '.' . $phpEx);
|
|
|
|
// Instantiate the database
|
|
$sql_db = 'dbal_' . $available_dbms[$dbms]['DRIVER'];
|
|
$db = new $sql_db();
|
|
$db->sql_connect($dbhost, $dbuser, $dbpasswd, $dbname, $dbport, false, false);
|
|
|
|
// NOTE: trigger_error does not work here.
|
|
$db->sql_return_on_error(true);
|
|
|
|
include_once($phpbb_root_path . 'includes/constants.' . $phpEx);
|
|
include_once($phpbb_root_path . 'includes/acp/acp_modules.' . $phpEx);
|
|
|
|
$_module = &new acp_modules();
|
|
$module_classes = array('acp', 'mcp', 'ucp');
|
|
|
|
// Add categories
|
|
foreach ($module_classes as $module_class)
|
|
{
|
|
$categories = array();
|
|
|
|
// Set the module class
|
|
$_module->module_class = $module_class;
|
|
|
|
foreach ($this->module_categories[$module_class] as $cat_name => $subs)
|
|
{
|
|
$module_data = array(
|
|
'module_basename' => '',
|
|
'module_enabled' => 1,
|
|
'module_display' => 1,
|
|
'parent_id' => 0,
|
|
'module_class' => $module_class,
|
|
'module_langname' => $cat_name,
|
|
'module_mode' => '',
|
|
'module_auth' => '',
|
|
);
|
|
|
|
// Add category
|
|
$_module->update_module_data($module_data, true);
|
|
|
|
// Check for last sql error happened
|
|
if ($db->sql_error_triggered)
|
|
{
|
|
$error = $db->sql_error($db->sql_error_sql);
|
|
$this->p_master->db_error($error['message'], $db->sql_error_sql, __LINE__, __FILE__);
|
|
}
|
|
|
|
$categories[$cat_name]['id'] = (int) $module_data['module_id'];
|
|
$categories[$cat_name]['parent_id'] = 0;
|
|
|
|
// Create sub-categories...
|
|
if (is_array($subs))
|
|
{
|
|
foreach ($subs as $level2_name)
|
|
{
|
|
$module_data = array(
|
|
'module_basename' => '',
|
|
'module_enabled' => 1,
|
|
'module_display' => 1,
|
|
'parent_id' => (int) $categories[$cat_name]['id'],
|
|
'module_class' => $module_class,
|
|
'module_langname' => $level2_name,
|
|
'module_mode' => '',
|
|
'module_auth' => '',
|
|
);
|
|
|
|
$_module->update_module_data($module_data, true);
|
|
|
|
// Check for last sql error happened
|
|
if ($db->sql_error_triggered)
|
|
{
|
|
$error = $db->sql_error($db->sql_error_sql);
|
|
$this->p_master->db_error($error['message'], $db->sql_error_sql, __LINE__, __FILE__);
|
|
}
|
|
|
|
$categories[$level2_name]['id'] = (int) $module_data['module_id'];
|
|
$categories[$level2_name]['parent_id'] = (int) $categories[$cat_name]['id'];
|
|
}
|
|
}
|
|
}
|
|
|
|
// Get the modules we want to add... returned sorted by name
|
|
$module_info = $_module->get_module_infos('', $module_class);
|
|
|
|
foreach ($module_info as $module_basename => $fileinfo)
|
|
{
|
|
foreach ($fileinfo['modes'] as $module_mode => $row)
|
|
{
|
|
foreach ($row['cat'] as $cat_name)
|
|
{
|
|
if (!isset($categories[$cat_name]))
|
|
{
|
|
continue;
|
|
}
|
|
$module_data = array(
|
|
'module_basename' => $module_basename,
|
|
'module_enabled' => 1,
|
|
'module_display' => (isset($row['display'])) ? $row['display'] : 1,
|
|
'parent_id' => (int) $categories[$cat_name]['id'],
|
|
'module_class' => $module_class,
|
|
'module_langname' => $row['title'],
|
|
'module_mode' => $module_mode,
|
|
'module_auth' => $row['auth'],
|
|
);
|
|
|
|
$_module->update_module_data($module_data, true);
|
|
|
|
// Check for last sql error happened
|
|
if ($db->sql_error_triggered)
|
|
{
|
|
$error = $db->sql_error($db->sql_error_sql);
|
|
$this->p_master->db_error($error['message'], $db->sql_error_sql, __LINE__, __FILE__);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Move some of the modules around since the code above will put them in the wrong place
|
|
if ($module_class == 'acp')
|
|
{
|
|
// Move main module 4 up...
|
|
$sql = 'SELECT *
|
|
FROM ' . MODULES_TABLE . "
|
|
WHERE module_basename = 'main'
|
|
AND module_class = 'acp'
|
|
AND module_mode = 'main'";
|
|
$result = $db->sql_query($sql);
|
|
$row = $db->sql_fetchrow($result);
|
|
$db->sql_freeresult($result);
|
|
|
|
$_module->move_module_by($row, 'move_up', 4);
|
|
|
|
// Move permissions intro screen module 4 up...
|
|
$sql = 'SELECT *
|
|
FROM ' . MODULES_TABLE . "
|
|
WHERE module_basename = 'permissions'
|
|
AND module_class = 'acp'
|
|
AND module_mode = 'intro'";
|
|
$result = $db->sql_query($sql);
|
|
$row = $db->sql_fetchrow($result);
|
|
$db->sql_freeresult($result);
|
|
|
|
$_module->move_module_by($row, 'move_up', 4);
|
|
|
|
// Move manage users screen module 5 up...
|
|
$sql = 'SELECT *
|
|
FROM ' . MODULES_TABLE . "
|
|
WHERE module_basename = 'users'
|
|
AND module_class = 'acp'
|
|
AND module_mode = 'overview'";
|
|
$result = $db->sql_query($sql);
|
|
$row = $db->sql_fetchrow($result);
|
|
$db->sql_freeresult($result);
|
|
|
|
$_module->move_module_by($row, 'move_up', 5);
|
|
}
|
|
|
|
if ($module_class == 'ucp')
|
|
{
|
|
// Move attachment module 4 down...
|
|
$sql = 'SELECT *
|
|
FROM ' . MODULES_TABLE . "
|
|
WHERE module_basename = 'attachments'
|
|
AND module_class = 'ucp'
|
|
AND module_mode = 'attachments'";
|
|
$result = $db->sql_query($sql);
|
|
$row = $db->sql_fetchrow($result);
|
|
$db->sql_freeresult($result);
|
|
|
|
$_module->move_module_by($row, 'move_down', 4);
|
|
}
|
|
|
|
// And now for the special ones
|
|
// (these are modules which appear in multiple categories and thus get added manually to some for more control)
|
|
if (isset($this->module_extras[$module_class]))
|
|
{
|
|
foreach ($this->module_extras[$module_class] as $cat_name => $mods)
|
|
{
|
|
$sql = 'SELECT module_id, left_id, right_id
|
|
FROM ' . MODULES_TABLE . "
|
|
WHERE module_langname = '" . $db->sql_escape($cat_name) . "'
|
|
AND module_class = '" . $db->sql_escape($module_class) . "'";
|
|
$result = $db->sql_query_limit($sql, 1);
|
|
$row2 = $db->sql_fetchrow($result);
|
|
$db->sql_freeresult($result);
|
|
|
|
foreach ($mods as $mod_name)
|
|
{
|
|
$sql = 'SELECT *
|
|
FROM ' . MODULES_TABLE . "
|
|
WHERE module_langname = '" . $db->sql_escape($mod_name) . "'
|
|
AND module_class = '" . $db->sql_escape($module_class) . "'
|
|
AND module_basename <> ''";
|
|
$result = $db->sql_query_limit($sql, 1);
|
|
$module_data = $db->sql_fetchrow($result);
|
|
$db->sql_freeresult($result);
|
|
|
|
unset($module_data['module_id']);
|
|
unset($module_data['left_id']);
|
|
unset($module_data['right_id']);
|
|
|
|
$module_data['parent_id'] = (int) $row2['module_id'];
|
|
|
|
$_module->update_module_data($module_data, true);
|
|
|
|
// Check for last sql error happened
|
|
if ($db->sql_error_triggered)
|
|
{
|
|
$error = $db->sql_error($db->sql_error_sql);
|
|
$this->p_master->db_error($error['message'], $db->sql_error_sql, __LINE__, __FILE__);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$_module->remove_cache_file();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Populate the language tables
|
|
*/
|
|
function add_language($mode, $sub)
|
|
{
|
|
global $db, $lang, $phpbb_root_path, $phpEx;
|
|
|
|
$dir = @opendir($phpbb_root_path . 'language');
|
|
|
|
if (!$dir)
|
|
{
|
|
$this->error('Unable to access the language directory', __LINE__, __FILE__);
|
|
}
|
|
|
|
while (($file = readdir($dir)) !== false)
|
|
{
|
|
$path = $phpbb_root_path . 'language/' . $file;
|
|
|
|
if (is_dir($path) && !is_link($path) && file_exists($path . '/iso.txt'))
|
|
{
|
|
$lang_file = file("{$phpbb_root_path}language/$path/iso.txt");
|
|
|
|
$lang_pack = array(
|
|
'lang_iso' => basename($path),
|
|
'lang_dir' => basename($path),
|
|
'lang_english_name' => trim(htmlspecialchars($lang_file[0])),
|
|
'lang_local_name' => trim(htmlspecialchars($lang_file[1], ENT_COMPAT, 'UTF-8')),
|
|
'lang_author' => trim(htmlspecialchars($lang_file[2], ENT_COMPAT, 'UTF-8')),
|
|
);
|
|
|
|
$db->sql_query('INSERT INTO ' . LANG_TABLE . ' ' . $db->sql_build_array('INSERT', $lang_pack));
|
|
|
|
if ($db->sql_error_triggered)
|
|
{
|
|
$error = $db->sql_error($db->sql_error_sql);
|
|
$this->p_master->db_error($error['message'], $db->sql_error_sql, __LINE__, __FILE__);
|
|
}
|
|
|
|
$valid_localized = array(
|
|
'icon_back_top', 'icon_contact_aim', 'icon_contact_email', 'icon_contact_icq', 'icon_contact_jabber', 'icon_contact_msnm', 'icon_contact_pm', 'icon_contact_yahoo', 'icon_contact_www', 'icon_post_delete', 'icon_post_edit', 'icon_post_info', 'icon_post_quote', 'icon_post_report', 'icon_user_online', 'icon_user_offline', 'icon_user_profile', 'icon_user_search', 'icon_user_warn', 'button_pm_forward', 'button_pm_new', 'button_pm_reply', 'button_topic_locked', 'button_topic_new', 'button_topic_reply',
|
|
);
|
|
|
|
$sql_ary = array();
|
|
|
|
$sql = 'SELECT *
|
|
FROM ' . STYLES_IMAGESET_TABLE;
|
|
$result = $db->sql_query($sql);
|
|
|
|
while ($imageset_row = $db->sql_fetchrow($result))
|
|
{
|
|
if (@file_exists("{$phpbb_root_path}styles/{$imageset_row['imageset_path']}/imageset/{$lang_pack['lang_iso']}/imageset.cfg"))
|
|
{
|
|
$cfg_data_imageset_data = parse_cfg_file("{$phpbb_root_path}styles/{$imageset_row['imageset_path']}/imageset/{$lang_pack['lang_iso']}/imageset.cfg");
|
|
foreach ($cfg_data_imageset_data as $image_name => $value)
|
|
{
|
|
if (strpos($value, '*') !== false)
|
|
{
|
|
if (substr($value, -1, 1) === '*')
|
|
{
|
|
list($image_filename, $image_height) = explode('*', $value);
|
|
$image_width = 0;
|
|
}
|
|
else
|
|
{
|
|
list($image_filename, $image_height, $image_width) = explode('*', $value);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$image_filename = $value;
|
|
$image_height = $image_width = 0;
|
|
}
|
|
|
|
if (strpos($image_name, 'img_') === 0 && $image_filename)
|
|
{
|
|
$image_name = substr($image_name, 4);
|
|
if (in_array($image_name, $valid_localized))
|
|
{
|
|
$sql_ary[] = array(
|
|
'image_name' => $image_name,
|
|
'image_filename' => $image_filename,
|
|
'image_height' => $image_height,
|
|
'image_width' => $image_width,
|
|
'imageset_id' => $imageset_row['imageset_id'],
|
|
'image_lang' => $lang_pack['lang_iso'],
|
|
);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
$db->sql_freeresult($result);
|
|
|
|
if (sizeof($sql_ary))
|
|
{
|
|
$db->sql_multi_insert(STYLES_IMAGESET_DATA_TABLE, $sql_ary);
|
|
|
|
if ($db->sql_error_triggered)
|
|
{
|
|
$error = $db->sql_error($db->sql_error_sql);
|
|
$this->p_master->db_error($error['message'], $db->sql_error_sql, __LINE__, __FILE__);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
closedir($dir);
|
|
}
|
|
|
|
/**
|
|
* Add search robots to the database
|
|
*/
|
|
function add_bots($mode, $sub)
|
|
{
|
|
global $db, $lang, $phpbb_root_path, $phpEx, $config;
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
// Fill the config array - it is needed by those functions we call
|
|
$sql = 'SELECT *
|
|
FROM ' . CONFIG_TABLE;
|
|
$result = $db->sql_query($sql);
|
|
|
|
$config = array();
|
|
while ($row = $db->sql_fetchrow($result))
|
|
{
|
|
$config[$row['config_name']] = $row['config_value'];
|
|
}
|
|
$db->sql_freeresult($result);
|
|
|
|
$sql = 'SELECT group_id
|
|
FROM ' . GROUPS_TABLE . "
|
|
WHERE group_name = 'BOTS'";
|
|
$result = $db->sql_query($sql);
|
|
$group_id = (int) $db->sql_fetchfield('group_id');
|
|
$db->sql_freeresult($result);
|
|
|
|
if (!$group_id)
|
|
{
|
|
// If we reach this point then something has gone very wrong
|
|
$this->p_master->error($lang['NO_GROUP'], __LINE__, __FILE__);
|
|
}
|
|
|
|
if (!function_exists('user_add'))
|
|
{
|
|
include($phpbb_root_path . 'includes/functions_user.' . $phpEx);
|
|
}
|
|
|
|
foreach ($this->bot_list as $bot_name => $bot_ary)
|
|
{
|
|
$user_row = array(
|
|
'user_type' => USER_IGNORE,
|
|
'group_id' => $group_id,
|
|
'username' => $bot_name,
|
|
'user_regdate' => time(),
|
|
'user_password' => '',
|
|
'user_colour' => '9E8DA7',
|
|
'user_email' => '',
|
|
'user_lang' => $default_lang,
|
|
'user_style' => 1,
|
|
'user_timezone' => 0,
|
|
'user_dateformat' => $lang['default_dateformat'],
|
|
'user_allow_massemail' => 0,
|
|
);
|
|
|
|
$user_id = user_add($user_row);
|
|
|
|
if (!$user_id)
|
|
{
|
|
// If we can't insert this user then continue to the next one to avoid inconsistant data
|
|
$this->p_master->db_error('Unable to insert bot into users table', $db->sql_error_sql, __LINE__, __FILE__, true);
|
|
continue;
|
|
}
|
|
|
|
$sql = 'INSERT INTO ' . BOTS_TABLE . ' ' . $db->sql_build_array('INSERT', array(
|
|
'bot_active' => 1,
|
|
'bot_name' => $bot_name,
|
|
'user_id' => $user_id,
|
|
'bot_agent' => $bot_ary[0],
|
|
'bot_ip' => $bot_ary[1],
|
|
));
|
|
|
|
$result = $db->sql_query($sql);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Sends an email to the board administrator with their password and some useful links
|
|
*/
|
|
function email_admin($mode, $sub)
|
|
{
|
|
global $auth, $config, $db, $lang, $template, $user, $phpbb_root_path, $phpEx;
|
|
|
|
$this->page_title = $lang['STAGE_FINAL'];
|
|
|
|
// Obtain any submitted data
|
|
foreach ($this->request_vars as $var)
|
|
{
|
|
$$var = (in_array($var, array('admin_name', 'dbpasswd', 'admin_pass1', 'admin_pass2'))) ? request_var($var, '', true) : request_var($var, '');
|
|
}
|
|
|
|
// Load the basic configuration data
|
|
include_once($phpbb_root_path . 'includes/constants.' . $phpEx);
|
|
|
|
$sql = 'SELECT *
|
|
FROM ' . CONFIG_TABLE;
|
|
$result = $db->sql_query($sql);
|
|
|
|
$config = array();
|
|
while ($row = $db->sql_fetchrow($result))
|
|
{
|
|
$config[$row['config_name']] = $row['config_value'];
|
|
}
|
|
$db->sql_freeresult($result);
|
|
|
|
$user->session_begin();
|
|
$auth->login($admin_name, $admin_pass1, false, true, true);
|
|
|
|
// OK, Now that we've reached this point we can be confident that everything
|
|
// is installed and working......I hope :)
|
|
// So it's time to send an email to the administrator confirming the details
|
|
// they entered
|
|
|
|
if ($config['email_enable'])
|
|
{
|
|
include_once($phpbb_root_path . 'includes/functions_messenger.' . $phpEx);
|
|
|
|
$messenger = new messenger(false);
|
|
|
|
$messenger->template('installed', $language);
|
|
|
|
$messenger->to($board_email1, $admin_name);
|
|
|
|
$messenger->headers('X-AntiAbuse: Board servername - ' . $config['server_name']);
|
|
$messenger->headers('X-AntiAbuse: User_id - ' . $user->data['user_id']);
|
|
$messenger->headers('X-AntiAbuse: Username - ' . $user->data['username']);
|
|
$messenger->headers('X-AntiAbuse: User IP - ' . $user->ip);
|
|
|
|
$messenger->assign_vars(array(
|
|
'USERNAME' => htmlspecialchars_decode($admin_name),
|
|
'PASSWORD' => htmlspecialchars_decode($admin_pass1))
|
|
);
|
|
|
|
$messenger->send(NOTIFY_EMAIL);
|
|
}
|
|
|
|
// And finally, add a note to the log
|
|
add_log('admin', 'LOG_INSTALL_INSTALLED', $config['version']);
|
|
|
|
$template->assign_vars(array(
|
|
'TITLE' => $lang['INSTALL_CONGRATS'],
|
|
'BODY' => sprintf($lang['INSTALL_CONGRATS_EXPLAIN'], $config['version'], append_sid($phpbb_root_path . 'install/index.' . $phpEx, 'mode=convert&language=' . $language), '../docs/README.html'),
|
|
'L_SUBMIT' => $lang['INSTALL_LOGIN'],
|
|
'U_ACTION' => append_sid($phpbb_root_path . 'adm/index.' . $phpEx),
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Generate a list of available mail server authentication methods
|
|
*/
|
|
function mail_auth_select($selected_method)
|
|
{
|
|
global $lang;
|
|
|
|
$auth_methods = array('PLAIN', 'LOGIN', 'CRAM-MD5', 'DIGEST-MD5', 'POP-BEFORE-SMTP');
|
|
$s_smtp_auth_options = '';
|
|
|
|
foreach ($auth_methods as $method)
|
|
{
|
|
$s_smtp_auth_options .= '<option value="' . $method . '"' . (($selected_method == $method) ? ' selected="selected"' : '') . '>' . $lang['SMTP_' . str_replace('-', '_', $method)] . '</option>';
|
|
}
|
|
|
|
return $s_smtp_auth_options;
|
|
}
|
|
|
|
|
|
/**
|
|
* The variables that we will be passing between pages
|
|
* Used to retrieve data quickly on each page
|
|
*/
|
|
var $request_vars = array('language', 'dbms', 'dbhost', 'dbport', 'dbuser', 'dbpasswd', 'dbname', 'table_prefix', 'default_lang', 'admin_name', 'admin_pass1', 'admin_pass2', 'board_email1', 'board_email2', 'img_imagick', 'ftp_path', 'ftp_user', 'ftp_pass', 'email_enable', 'smtp_delivery', 'smtp_host', 'smtp_auth', 'smtp_user', 'smtp_pass', 'cookie_secure', 'force_server_vars', 'server_protocol', 'server_name', 'server_port', 'script_path');
|
|
|
|
/**
|
|
* The information below will be used to build the input fields presented to the user
|
|
*/
|
|
var $db_config_options = array(
|
|
'legend1' => 'DB_CONFIG',
|
|
'dbms' => array('lang' => 'DBMS', 'type' => 'select', 'options' => 'dbms_select(\'{VALUE}\')', 'explain' => false),
|
|
'dbhost' => array('lang' => 'DB_HOST', 'type' => 'text:25:100', 'explain' => true),
|
|
'dbport' => array('lang' => 'DB_PORT', 'type' => 'text:25:100', 'explain' => true),
|
|
'dbname' => array('lang' => 'DB_NAME', 'type' => 'text:25:100', 'explain' => false),
|
|
'dbuser' => array('lang' => 'DB_USERNAME', 'type' => 'text:25:100', 'explain' => false),
|
|
'dbpasswd' => array('lang' => 'DB_PASSWORD', 'type' => 'password:25:100', 'explain' => false),
|
|
'table_prefix' => array('lang' => 'TABLE_PREFIX', 'type' => 'text:25:100', 'explain' => false),
|
|
);
|
|
var $admin_config_options = array(
|
|
'legend1' => 'ADMIN_CONFIG',
|
|
'default_lang' => array('lang' => 'DEFAULT_LANG', 'type' => 'select', 'options' => '$this->module->inst_language_select(\'{VALUE}\')', 'explain' => false),
|
|
'admin_name' => array('lang' => 'ADMIN_USERNAME', 'type' => 'text:25:100', 'explain' => true),
|
|
'admin_pass1' => array('lang' => 'ADMIN_PASSWORD', 'type' => 'password:25:100', 'explain' => true),
|
|
'admin_pass2' => array('lang' => 'ADMIN_PASSWORD_CONFIRM', 'type' => 'password:25:100', 'explain' => false),
|
|
'board_email1' => array('lang' => 'CONTACT_EMAIL', 'type' => 'text:25:100', 'explain' => false),
|
|
'board_email2' => array('lang' => 'CONTACT_EMAIL_CONFIRM', 'type' => 'text:25:100', 'explain' => false),
|
|
);
|
|
var $advanced_config_options = array(
|
|
'legend1' => 'ACP_EMAIL_SETTINGS',
|
|
'email_enable' => array('lang' => 'ENABLE_EMAIL', 'type' => 'radio:enabled_disabled', 'explain' => true),
|
|
'smtp_delivery' => array('lang' => 'USE_SMTP', 'type' => 'radio:yes_no', 'explain' => true),
|
|
'smtp_host' => array('lang' => 'SMTP_SERVER', 'type' => 'text:25:50', 'explain' => false),
|
|
'smtp_auth' => array('lang' => 'SMTP_AUTH_METHOD', 'type' => 'select', 'options' => '$this->module->mail_auth_select(\'{VALUE}\')', 'explain' => true),
|
|
'smtp_user' => array('lang' => 'SMTP_USERNAME', 'type' => 'text:25:255', 'explain' => true),
|
|
'smtp_pass' => array('lang' => 'SMTP_PASSWORD', 'type' => 'password:25:255', 'explain' => true),
|
|
|
|
'legend2' => 'SERVER_URL_SETTINGS',
|
|
'cookie_secure' => array('lang' => 'COOKIE_SECURE', 'type' => 'radio:enabled_disabled', 'explain' => true),
|
|
'force_server_vars' => array('lang' => 'FORCE_SERVER_VARS', 'type' => 'radio:yes_no', 'explain' => true),
|
|
'server_protocol' => array('lang' => 'SERVER_PROTOCOL', 'type' => 'text:10:10', 'explain' => true),
|
|
'server_name' => array('lang' => 'SERVER_NAME', 'type' => 'text:40:255', 'explain' => true),
|
|
'server_port' => array('lang' => 'SERVER_PORT', 'type' => 'text:5:5', 'explain' => true),
|
|
'script_path' => array('lang' => 'SCRIPT_PATH', 'type' => 'text::255', 'explain' => true),
|
|
);
|
|
|
|
/**
|
|
* Specific PHP modules we may require for certain optional or extended features
|
|
*/
|
|
var $php_dlls_other = array('zlib', 'ftp', 'gd', 'xml');
|
|
|
|
/**
|
|
* A list of the web-crawlers/bots we recognise by default
|
|
*
|
|
* Candidates but not included:
|
|
* 'Accoona [Bot]' 'Accoona-AI-Agent/'
|
|
* 'ASPseek [Crawler]' 'ASPseek/'
|
|
* 'Boitho [Crawler]' 'boitho.com-dc/'
|
|
* 'Bunnybot [Bot]' 'powered by www.buncat.de'
|
|
* 'Cosmix [Bot]' 'cfetch/'
|
|
* 'Crawler Search [Crawler]' '.Crawler-Search.de'
|
|
* 'Findexa [Crawler]' 'Findexa Crawler ('
|
|
* 'GBSpider [Spider]' 'GBSpider v'
|
|
* 'genie [Bot]' 'genieBot ('
|
|
* 'Hogsearch [Bot]' 'oegp v. 1.3.0'
|
|
* 'Insuranco [Bot]' 'InsurancoBot'
|
|
* 'IRLbot [Bot]' 'http://irl.cs.tamu.edu/crawler'
|
|
* 'ISC Systems [Bot]' 'ISC Systems iRc Search'
|
|
* 'Jyxobot [Bot]' 'Jyxobot/'
|
|
* 'Kraehe [Metasuche]' '-DIE-KRAEHE- META-SEARCH-ENGINE/'
|
|
* 'LinkWalker' 'LinkWalker'
|
|
* 'MMSBot [Bot]' 'http://www.mmsweb.at/bot.html'
|
|
* 'Naver [Bot]' 'nhnbot@naver.com)'
|
|
* 'NetResearchServer' 'NetResearchServer/'
|
|
* 'Nimble [Crawler]' 'NimbleCrawler'
|
|
* 'Ocelli [Bot]' 'Ocelli/'
|
|
* 'Onsearch [Bot]' 'onCHECK-Robot'
|
|
* 'Orange [Spider]' 'OrangeSpider'
|
|
* 'Sproose [Bot]' 'http://www.sproose.com/bot'
|
|
* 'Susie [Sync]' '!Susie (http://www.sync2it.com/susie)'
|
|
* 'Tbot [Bot]' 'Tbot/'
|
|
* 'Thumbshots [Capture]' 'thumbshots-de-Bot'
|
|
* 'Vagabondo [Crawler]' 'http://webagent.wise-guys.nl/'
|
|
* 'Walhello [Bot]' 'appie 1.1 (www.walhello.com)'
|
|
* 'WissenOnline [Bot]' 'WissenOnline-Bot'
|
|
* 'WWWeasel [Bot]' 'WWWeasel Robot v'
|
|
* 'Xaldon [Spider]' 'Xaldon WebSpider'
|
|
*/
|
|
var $bot_list = array(
|
|
'AdsBot [Google]' => array('AdsBot-Google', ''),
|
|
'Alexa [Bot]' => array('ia_archiver', ''),
|
|
'Alta Vista [Bot]' => array('Scooter/', ''),
|
|
'Ask Jeeves [Bot]' => array('Ask Jeeves', ''),
|
|
'Baidu [Spider]' => array('Baiduspider+(', ''),
|
|
'Exabot [Bot]' => array('Exabot/', ''),
|
|
'FAST Enterprise [Crawler]' => array('FAST Enterprise Crawler', ''),
|
|
'FAST WebCrawler [Crawler]' => array('FAST-WebCrawler/', ''),
|
|
'Francis [Bot]' => array('http://www.neomo.de/', ''),
|
|
'Gigabot [Bot]' => array('Gigabot/', ''),
|
|
'Google Adsense [Bot]' => array('Mediapartners-Google/', ''),
|
|
'Google Desktop' => array('Google Desktop', ''),
|
|
'Google Feedfetcher' => array('Feedfetcher-Google', ''),
|
|
'Google [Bot]' => array('Googlebot', ''),
|
|
'Heise IT-Markt [Crawler]' => array('heise-IT-Markt-Crawler', ''),
|
|
'Heritrix [Crawler]' => array('heritrix/1.', ''),
|
|
'IBM Research [Bot]' => array('ibm.com/cs/crawler', ''),
|
|
'ICCrawler - ICjobs' => array('ICCrawler - ICjobs', ''),
|
|
'ichiro [Crawler]' => array('ichiro/2', ''),
|
|
'Majestic-12 [Bot]' => array('MJ12bot/', ''),
|
|
'Metager [Bot]' => array('MetagerBot/', ''),
|
|
'MSN NewsBlogs' => array('msnbot-NewsBlogs/', ''),
|
|
'MSN [Bot]' => array('msnbot/', ''),
|
|
'MSNbot Media' => array('msnbot-media/', ''),
|
|
'NG-Search [Bot]' => array('NG-Search/', ''),
|
|
'Nutch [Bot]' => array('http://lucene.apache.org/nutch/', ''),
|
|
'Nutch/CVS [Bot]' => array('NutchCVS/', ''),
|
|
'OmniExplorer [Bot]' => array('OmniExplorer_Bot/', ''),
|
|
'Online link [Validator]' => array('online link validator', ''),
|
|
'psbot [Picsearch]' => array('psbot/0', ''),
|
|
'Seekport [Bot]' => array('Seekbot/', ''),
|
|
'Sensis [Crawler]' => array('Sensis Web Crawler', ''),
|
|
'SEO Crawler' => array('SEO search Crawler/', ''),
|
|
'Seoma [Crawler]' => array('Seoma [SEO Crawler]', ''),
|
|
'SEOSearch [Crawler]' => array('SEOsearch/', ''),
|
|
'Snappy [Bot]' => array('Snappy/1.1 ( http://www.urltrends.com/ )', ''),
|
|
'Steeler [Crawler]' => array('http://www.tkl.iis.u-tokyo.ac.jp/~crawler/', ''),
|
|
'Synoo [Bot]' => array('SynooBot/', ''),
|
|
'Telekom [Bot]' => array('crawleradmin.t-info@telekom.de', ''),
|
|
'TurnitinBot [Bot]' => array('TurnitinBot/', ''),
|
|
'Voyager [Bot]' => array('voyager/1.0', ''),
|
|
'W3 [Sitesearch]' => array('W3 SiteSearch Crawler', ''),
|
|
'W3C [Linkcheck]' => array('W3C-checklink/', ''),
|
|
'W3C [Validator]' => array('W3C_*Validator', ''),
|
|
'WiseNut [Bot]' => array('http://www.WISEnutbot.com', ''),
|
|
'YaCy [Bot]' => array('yacybot', ''),
|
|
'Yahoo MMCrawler [Bot]' => array('Yahoo-MMCrawler/', ''),
|
|
'Yahoo Slurp [Bot]' => array('Yahoo! DE Slurp', ''),
|
|
'Yahoo [Bot]' => array('Yahoo! Slurp', ''),
|
|
'YahooSeeker [Bot]' => array('YahooSeeker/', ''),
|
|
);
|
|
|
|
/**
|
|
* Define the module structure so that we can populate the database without
|
|
* needing to hard-code module_id values
|
|
*/
|
|
var $module_categories = array(
|
|
'acp' => array(
|
|
'ACP_CAT_GENERAL' => array(
|
|
'ACP_QUICK_ACCESS',
|
|
'ACP_BOARD_CONFIGURATION',
|
|
'ACP_CLIENT_COMMUNICATION',
|
|
'ACP_SERVER_CONFIGURATION',
|
|
),
|
|
'ACP_CAT_FORUMS' => array(
|
|
'ACP_MANAGE_FORUMS',
|
|
'ACP_FORUM_BASED_PERMISSIONS',
|
|
),
|
|
'ACP_CAT_POSTING' => array(
|
|
'ACP_MESSAGES',
|
|
'ACP_ATTACHMENTS',
|
|
),
|
|
'ACP_CAT_USERGROUP' => array(
|
|
'ACP_CAT_USERS',
|
|
'ACP_GROUPS',
|
|
'ACP_USER_SECURITY',
|
|
),
|
|
'ACP_CAT_PERMISSIONS' => array(
|
|
'ACP_GLOBAL_PERMISSIONS',
|
|
'ACP_FORUM_BASED_PERMISSIONS',
|
|
'ACP_PERMISSION_ROLES',
|
|
'ACP_PERMISSION_MASKS',
|
|
),
|
|
'ACP_CAT_STYLES' => array(
|
|
'ACP_STYLE_MANAGEMENT',
|
|
'ACP_STYLE_COMPONENTS',
|
|
),
|
|
'ACP_CAT_MAINTENANCE' => array(
|
|
'ACP_FORUM_LOGS',
|
|
'ACP_CAT_DATABASE',
|
|
),
|
|
'ACP_CAT_SYSTEM' => array(
|
|
'ACP_AUTOMATION',
|
|
'ACP_GENERAL_TASKS',
|
|
'ACP_MODULE_MANAGEMENT',
|
|
),
|
|
'ACP_CAT_DOT_MODS' => null,
|
|
),
|
|
'mcp' => array(
|
|
'MCP_MAIN' => null,
|
|
'MCP_QUEUE' => null,
|
|
'MCP_REPORTS' => null,
|
|
'MCP_NOTES' => null,
|
|
'MCP_WARN' => null,
|
|
'MCP_LOGS' => null,
|
|
'MCP_BAN' => null,
|
|
),
|
|
'ucp' => array(
|
|
'UCP_MAIN' => null,
|
|
'UCP_PROFILE' => null,
|
|
'UCP_PREFS' => null,
|
|
'UCP_PM' => null,
|
|
'UCP_USERGROUPS' => null,
|
|
'UCP_ZEBRA' => null,
|
|
),
|
|
);
|
|
|
|
var $module_extras = array(
|
|
'acp' => array(
|
|
'ACP_QUICK_ACCESS' => array(
|
|
'ACP_MANAGE_USERS',
|
|
'ACP_GROUPS_MANAGE',
|
|
'ACP_MANAGE_FORUMS',
|
|
'ACP_MOD_LOGS',
|
|
'ACP_BOTS',
|
|
'ACP_PHP_INFO',
|
|
),
|
|
'ACP_FORUM_BASED_PERMISSIONS' => array(
|
|
'ACP_FORUM_PERMISSIONS',
|
|
'ACP_FORUM_MODERATORS',
|
|
'ACP_USERS_FORUM_PERMISSIONS',
|
|
'ACP_GROUPS_FORUM_PERMISSIONS',
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
?>
|