From 28b08499da2501510ddfd6ce552f8fafd3eb7e41 Mon Sep 17 00:00:00 2001 From: the_systech Date: Fri, 28 Sep 2001 20:12:23 +0000 Subject: [PATCH] Updates for Install Process.... git-svn-id: file:///svn/phpbb/trunk@1102 89ea8834-ac86-4346-8a33-228a782c2dd0 --- phpBB/includes/installation.php | 59 ++++ phpBB/install.php | 388 ++++++++++++++++++++++ phpBB/language/lang_english.php | 22 +- phpBB/templates/Default/install.tpl | 38 +++ phpBB/templates/Default/install_error.tpl | 29 ++ 5 files changed, 535 insertions(+), 1 deletion(-) create mode 100644 phpBB/includes/installation.php create mode 100644 phpBB/install.php create mode 100644 phpBB/templates/Default/install.tpl create mode 100644 phpBB/templates/Default/install_error.tpl diff --git a/phpBB/includes/installation.php b/phpBB/includes/installation.php new file mode 100644 index 0000000000..93d25effa2 --- /dev/null +++ b/phpBB/includes/installation.php @@ -0,0 +1,59 @@ + '2', + 'themes_name' => 'Default', + 'template_name' => 'Default', + 'td_color1' => 'CCCCCC', + 'td_color2' => 'DDDDDD' +); +$default_language = 'english'; +$default_template = 'Default'; + +$available_dbms[] = array( + "LABEL" => "MySQL", + "VALUE" => "mysql" +); +$available_dbms[] = array( + "LABEL" => "MS SQL", + "VALUE" => "mssql" +); +$available_dbms[] = array( + "LABEL" => "Postgres", + "VALUE" => "postgres" +); +$available_dbms[] = array( + "LABEL" => "ODBC - MSAccess", + "VALUE" => "odbc:access" +); +$available_dbms[] = array( + "LABEL" => "ODBC - DB2", + "VALUE" => "odbc:db2" +); +$available_lang[] = 'english'; +?> diff --git a/phpBB/install.php b/phpBB/install.php new file mode 100644 index 0000000000..ca3d5b4e6b --- /dev/null +++ b/phpBB/install.php @@ -0,0 +1,388 @@ +set_filenames(array( + "body" => "install_error.tpl") + ); + $template->assign_vars(array( + "L_TITLE" => $lang['Installer_Error'], + "L_ERROR" => $lang['Previous_Install']) + ); + $template->pparse('body'); + die(); +} +// +// Ok we haven't installed before so lets work our way through the various +// steps of the install process. This could turn out to be quite a lengty +// process. +// +$installStep = ($HTTP_POST_VARS['installStep']) ? $HTTP_POST_VARS['installStep']: $HTTP_GET_VARS['installStep']; +$dbms = ($HTTP_POST_VARS['dbms']); +if( !isset($installStep) || $installStep == 0) +{ + // + // Step 0 gather the pertinant info for database setup... + // Namely dbms, dbhost, dbname, dbuser, and dbpasswd. + // + $template->set_filenames(array( + "body" => "install.tpl") + ); + $template->assign_vars(array( + "L_INSTRUCT" => $lang['Inst_Step_0'], + "L_SUBMIT" => $lang['Start_Install'], + "S_FORM_ACTION" => 'install.'.$phpEx) + ); + $template->assign_block_vars("hidden_fields", array( + "NAME" => "installStep", + "VALUE" => "1") + ); + $template->assign_block_vars("inputs", array( + "NAME" => "dbhost", + "L_LABEL" => $lang['DB_Host'] . ':') + ); + $template->assign_block_vars("inputs", array( + "NAME" => "dbname", + "L_LABEL" => $lang['DB_Name'] . ':') + ); + $template->assign_block_vars("inputs", array( + "NAME" => "dbuser", + "L_LABEL" => $lang['Database'] . ' ' . $lang['Username'] . ':') + ); + $template->assign_block_vars("inputs", array( + "NAME" => "dbpasswd", + "L_LABEL" => $lang['Database'] . ' ' . $lang['Password'] . ':') + ); + $template->assign_block_vars("selects", array( + "NAME" => "language", + "L_LABEL" => $lang['Install_lang']) + ); + for($i = 0; $i < count($available_lang); $i++) + { + $template->assign_block_vars("selects.options", array( + "LABEL" => $available_lang[$i], + "VALUE" => $available_lang[$i]) + ); + } + $template->assign_block_vars("selects", array( + "NAME" => "dbms", + "L_LABEL" => $lang['dbms']) + ); + for($i = 0; $i < count($available_dbms); $i++) + { + $template->assign_block_vars("selects.options", array( + "LABEL" => $available_dbms[$i]['LABEL'], + "VALUE" => $available_dbms[$i]['VALUE']) + ); + } + $template->pparse("body"); + exit(); +} +// +// If the dbms is set to be odbc then we need to skip most of the +// steps and go straight to writing the config file. We'll spit +// out some additional instructions later on what to do after installation +// for the odbc DBMS. +// +if (ereg(':', $dbms) && $installStep < 2) +{ + $dbms = explode(':', $dbms); + $dbhost = $dbms[1] . ':' . $dbhost; + $dbms = $dbms[0]; + $installStep = 2; +} +elseif ( isset($dbms) ) +{ + include($phpbb_root_path.'includes/db.'.$phpEx); +} + +$dbms_schema = 'db/'.$dbms.'_schema.sql'; +$dbms_basic = 'db/'.$dbms.'_basic.sql'; +$remove_remarks = ($dbms == 'mysql')?'remove_remarks':'remove_comments'; +$delimiter = ( $dbms == 'mssql' )?'GO':';'; +switch ( $installStep ) +{ + case 1: + // + // Ok we have the db info go ahead and read in the relevant schema + // and work on building the table.. probably ought to provide some + // kind of feedback to the user as we are working here in order + // to let them know we are actually doing something. + // + $sql_query = fread(fopen($dbms_schema, 'r'), filesize($dbms_schema)); + $sql_query = $remove_remarks($sql_query); + $sql_query = split_sql_file($sql_query, $delimiter); + $sql_count = count($sql_query); + for($i = 0; $i < $sql_count; $i++) + { + $result = $db->sql_query($sql_query[$i]); + if( !$result ) + { + $template->set_filenames(array( + "body" => "install_error.tpl") + ); + $template->assign_vars(array( + "L_TITLE" => $lang['Installer_Error'], + "L_ERROR" => $lang['Install_db_error']) + ); + $template->pparse('body'); + die(); + } + } + // + // Ok tables have been built, let's fill in the basic information + // + $sql_query = fread(fopen($dbms_basic, 'r'), filesize($dbms_basic)); + $sql_query = $remove_remarks($sql_query); + $sql_query = split_sql_file($sql_query, $delimiter); + $sql_count = count($sql_query); + for($i = 0; $i < $sql_count; $i++) + { + $result = $db->sql_query($sql_query[$i]); + if( !$result ) + { + $template->set_filenames(array( + "body" => "install_error.tpl") + ); + $template->assign_vars(array( + "L_TITLE" => $lang['Installer_Error'], + "L_ERROR" => $lang['Install_db_error']) + ); + $template->pparse('body'); + die(); + } + } + // + // Then let's prompt for an admin username and password. + // + $template->set_filenames(array( + "body" => "install.tpl") + ); + $template->assign_vars(array( + "L_INSTRUCT" => $lang['Inst_Step_1'], + "L_SUBMIT" => $lang['Create_User'], + "S_FORM_ACTION" => 'install.'.$phpEx) + ); + // + // Carry over all of the variables from the last form. + // + reset( $HTTP_POST_VARS ); + while( list( $key, $val ) = each( $HTTP_POST_VARS )) + { + if( $key != 'installStep' ) + { + $template->assign_block_vars("hidden_fields", array( + "NAME" => $key, + "VALUE" => $val) + ); + } + } + $template->assign_block_vars("hidden_fields", array( + "NAME" => "installStep", + "VALUE" => "2") + ); + $template->assign_block_vars("inputs", array( + "NAME" => "admin_name", + "L_LABEL" => $lang['Username']) + ); + $template->assign_block_vars("inputs", array( + "NAME" => "admin_pass1", + "L_LABEL" => $lang['Password']) + ); + $template->assign_block_vars("inputs", array( + "NAME" => "admin_pass2", + "L_LABEL" => $lang['Confirm'] . ' ' . $lang['Password']) + ); + $template->pparse('body'); + exit(); + break; + case 2: + // + // Ok at this point they have entered their admin password, let's go + // ahead and create the admin account with some basic default information + // that they can customize later, and write out the config file. After + // this we are going to pass them over to the admin_forum.php script + // to set up their forum defaults. + // + if( $dbms == 'odbc' ) + { + // + // Output the instructions for the odbc... + // + $template->set_filenames(array( + "body" => "install.tpl") + ); + + $template->assign_vars(array( + "L_INSTRUCT" => $lang['ODBC_Instructs'], + "L_SUBMIT" => $lang['OK'], + "S_FORM_ACTION" => 'install.'.$phpEx) + ); + $template->assign_block_vars("hidden_fields", array( + "NAME" => "installStep", + "VALUE" => '3') + ); + exit(); + } + if( $HTTP_POST_VARS['admin_pass1'] != $HTTP_POST_VARS['admin_pass2'] ) + { + $template->set_filenames(array( + "body" => "install.tpl") + ); + $template->assign_vars(array( + "L_INSTRUCT" => $lang['Password_mismatch'].'
'.$lang['Inst Step 1'], + "L_SUBMIT" => $lang['Create_User'], + "S_FORM_ACTION" => 'install.'.$phpEx) + ); + $template->pparse("body"); + exit(); + // + // Output the current PostVars + // + reset( $HTTP_POST_VARS ); + while( list( $key, $val ) = each( $HTTP_POST_VARS )) + { + if( $key != 'installStep' ) + { + $template->assign_block_vars("hidden_fields", array( + "NAME" => $key, + "VALUE" => $val) + ); + } + } + $template->assign_block_vars("hidden_fields", array( + "NAME" => "installStep", + "VALUE" => "2") + ); + $template->assign_block_vars("inputs", array( + "NAME" => "admin_name", + "LABEL" => $lang['Username']) + ); + $template->assign_block_vars("inputs", array( + "NAME" => "admin_pass1", + "LABEL" => $lang['Password']) + ); + $template->assign_block_vars("inputs", array( + "NAME" => "admin_pass2", + "LABEL" => $lang['Confirm'] . ' ' . $lang['Password']) + ); + $template->pparse('body'); + exit(); + } + else + { + // + // Update the default admin user with their information. + // + $sql = "UPDATE phpbb_users + SET username='".$HTTP_POST_VARS['admin_name']."', + user_password='".md5($HTTP_POST_VARS['admin_pass1'])."' + WHERE username = 'Admin'"; + $result = $db->sql_query($sql); + if( !$result ) + { + $template->set_filenames(array( + "body" => "install_error.tpl") + ); + $template->assign_vars(array( + "L_TITLE" => $lang['Installer_Error'], + "L_ERROR" => $lang['Install_db_error']. mysql_error()) + ); + $template->pparse('body'); + die(); + } + // + // Write out the config file. + // + $config_data = ''; + @umask(0111); + $fp = fopen('config.php', 'w'); + $result = fputs($fp, $config_data, strlen($config_data)); + fclose($fp); + // + // Ok we are basically done with the install process let's go on + // and let the user configure their board now. + // We are going to do this by calling the admin_board.php from the + // normal board admin section. + // + $template->set_filenames(array( + "body" => "install.tpl") + ); + $template->assign_vars(array( + "L_INSTRUCT" => $lang['Inst_Step_2'], + "L_SUBMIT" => $lang['Finish_Install'], + "S_FORM_ACTION" => 'login.'.$phpEx) + ); + + $template->assign_block_vars("hidden_fields", array( + "NAME" => 'username', + "VALUE" => $admin_name) + ); + $template->assign_block_vars("hidden_fields", array( + "NAME" => 'password', + "VALUE" => $admin_pass1) + ); + $template->assign_block_vars("hidden_fields", array( + "NAME" => 'submit', + "VALUE" => 'Login') + ); + $template->assign_block_vars("hidden_fields", array( + "NAME" => 'forward_page', + "VALUE" => 'admin/admin_board.'.$phpEx.'?mode=config') + ); + $template->pparse('body'); + exit(); + } + break; +} diff --git a/phpBB/language/lang_english.php b/phpBB/language/lang_english.php index 75f2cb815e..44648c5679 100755 --- a/phpBB/language/lang_english.php +++ b/phpBB/language/lang_english.php @@ -944,6 +944,26 @@ $lang['Word_removed'] = "The selected word censor has been successfully removed" $lang['Mass_email_explain'] = "Here you can email a message to either all of your users, or all users of a specific group. To do this, an email will be sent out to the administrative email address supplied, with a blind carbon copy sent to all receptients. If you are emailing a large group of people, please be patient after submiting and DO NOT stop the page halfway through. It is normal for amass emailing to take a long time."; $lang['Compose'] = "Compose"; +// +// Install Process +// +$lang['Installer_Error'] = "An error has occured during installation."; +$lang['Previous_Install'] = "A previous installtion has been detected."; +$lang['Inst_Step_0'] = "Thank you for choosing phpBB version 2. Please select your chosen database server, and enter the information for your database server host, database name, username, and password. NOTE: The database should already exist."; +$lang['Start_Install'] = "Start Install"; +$lang['DB_Host'] = "Database Server Hostname"; +$lang['DB_Name'] = "Your Database Name"; +$lang['Database'] = "Your Database"; +$lang['Install_lang'] = "Choose Language for Installation"; +$lang['dbms'] = "Database Type"; +$lang['Inst_Step_1'] = "Your database tables have been created and filled with some basic default data. Please enter your chosen phpBB Admin Username and Password."; +$lang['Create_User'] = "Create User"; +$lang['Inst_Step_2'] = "Your admin username has been created. At this point your installation is basically completed, you will now be taken to a screen which will allow you to specify some basic default settings for your board."; +$lang['Finish_Install'] = "Finish Installation"; +$lang['Install_db_error'] = "An error occured trying to update the database"; +$lang['ODBC_Instructs'] = "Someone please write some odbc instructions in the \$lang['ODBC_Instructs'] variable!"; + + // // End // ------------------------------------------------- @@ -983,4 +1003,4 @@ $l_emailpass = "Email Lost Password"; $l_passexplain = "Please fill out the form, a new password will be sent to your Email address"; $l_sendpass = "Send Password"; -?> \ No newline at end of file +?> diff --git a/phpBB/templates/Default/install.tpl b/phpBB/templates/Default/install.tpl new file mode 100644 index 0000000000..37ee60a182 --- /dev/null +++ b/phpBB/templates/Default/install.tpl @@ -0,0 +1,38 @@ + + + phpBB Version 2.0 Installation + + +
+ + + + + + + +
{L_INSTRUCT}
+ + + + + + + + + + + + + + + + +
{selects.L_LABEL}
{inputs.L_LABEL}
+
+ + diff --git a/phpBB/templates/Default/install_error.tpl b/phpBB/templates/Default/install_error.tpl new file mode 100644 index 0000000000..3aa08687da --- /dev/null +++ b/phpBB/templates/Default/install_error.tpl @@ -0,0 +1,29 @@ + + + phpBB Version 2.0 Installer + + + + + + + + + +
+

{L_TITLE}

+
+ + + + +
+ + + + +
{L_ERROR}
+
+
+ +