' . safeHTMLstr(mysqli_connect_error()); } else { // Specify UTF-8 use for connection mysqli_query($dbtest, "SET NAMES 'utf8'"); // Create DB? if (isset($_POST['dboptions']) && ($_POST['dboptions'] == 'createNload')) { if (preg_match("/^[\w-]+$/", $_POST['dbname'])) { $q = "CREATE DATABASE `" . $_POST['dbname'] . "` DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci"; if (!mysqli_query($dbtest, $q) && (mysqli_errno($dbtest) != 1007)) { // 1007=exists $e = 'Unable to create database ' . safeHTMLstr($_POST['dbname']) . ". DB Error:
" . safeHTMLstr(mysqli_error($dbtest) . " (" . mysqli_errno($dbtest) . ")"); } } else { $e = 'Database name limited to letters, numbers, hyphen, and underscore'; } } if (empty($e)) { // Check prefix if (!empty($_POST['dbprefix']) && (!preg_match("/^[\w-]{0,40}$/",$_POST['dbprefix']))) { $e = 'Invalid table prefix; use up to 40 letters, numbers, and the underscore.'; } // Attempt to access DB elseif (!mysqli_select_db($dbtest, $_POST['dbname'])) { $e = 'Unable to access database ' . safeHTMLstr($_POST['dbname']); } else { // Save db info if (! $fp = fopen(OCC_LIB_DIR . 'config-sample.php', 'r')) { err('Config template file (lib/config-sample.php) does not exist. Check that you have a full OpenConf distribution and click the Restart Install link above.', $hdr, $hdrfn, false); } if (!$optionFile = fread($fp, filesize(OCC_LIB_DIR . 'config-sample.php'))) { fclose($fp); err("Unable to read from config file", $hdr, $hdrfn, false); } fclose($fp); replaceConstantValue('OCC_SESSION_VAR_NAME', 'OPENCONF' . substr(oc_idGen(),3,4), $optionFile); // assign a (hopefully) unique session name in case of multiple installations replaceConstantValue('OCC_DB_USER', $_POST['dbuser'], $optionFile); replaceConstantValue('OCC_DB_PASSWORD', $_POST['dbpw'], $optionFile); replaceConstantValue('OCC_DB_HOST', $_POST['dbhost'], $optionFile); replaceConstantValue('OCC_DB_PORT', $_POST['dbport'], $optionFile); replaceConstantValue('OCC_DB_NAME', $_POST['dbname'], $optionFile); replaceConstantValue('OCC_DB_PREFIX', $_POST['dbprefix'], $optionFile); if (! $fp = fopen(OCC_CONFIG_FILE,'w')) { err('Config file (config.php) cannot be created or is not writeable. Try creating a blank config.php file manually and ensure file permissions allow config.php to be written to by the server; then click the Restart Install link above.', $hdr, $hdrfn, false); } if (!fwrite($fp, $optionFile)) { fclose($fp); err("Unable to write to config file", $hdr, $hdrfn, false); } fclose($fp); // Load schema if ($dbfile = file_get_contents(OCC_LIB_DIR . "DB.sql")) { // create tables if (preg_match_all("/(CREATE [^;]+);/", $dbfile, $matches)) { foreach ($matches[1] as $m) { // add table prefix $m = preg_replace("/(CREATE TABLE `?)/", "$1" . slashQuote(stripslashes($_POST['dbprefix'])), $m); if (!mysqli_query($dbtest, $m)) { $e = "Error on loading schema -- " . safeHTMLstr(mysqli_error($dbtest)) . ".
Database may need to be reset"; break; } } } else { err("No schema found in DB.sql file", $hdr, $hdrfn, false); } // insert data if (empty($e) && preg_match_all("/(INSERT [^;]+);/", $dbfile, $matches)) { foreach ($matches[1] as $m) { // add table prefix $m = preg_replace("/(INSERT INTO `?)/", "$1" . slashQuote(stripslashes($_POST['dbprefix'])), $m); if (!mysqli_query($dbtest, $m)) { $e = "Error on loading schema -- " . safeHTMLstr(mysqli_error($dbtest)) . ".
Database may need to be reset"; break; } } } } else { $e = 'Unable to load schema from DB.sql. Try loading it manually (see INSTALL instructions).'; } if (empty($e)) { mysqli_close($dbtest); header("Location: install-account.php"); exit; } } } mysqli_close($dbtest); } $dbuser = varValue('dbuser', $_POST); $dbname = varValue('dbname', $_POST); $dbhost = varValue('dbhost', $_POST); $dbport = varValue('dbport', $_POST, 3306); $dbprefix = varValue('dbprefix', $_POST); } else { $dbuser = (defined('OCC_DB_USER') ? OCC_DB_USER : ''); $dbname = (defined('OCC_DB_NAME') ? OCC_DB_NAME : ''); $dbhost = (defined('OCC_DB_HOST') ? OCC_DB_HOST : ''); $dbport = (defined('OCC_DB_PORT') ? OCC_DB_PORT : 3306); $dbprefix = (defined('OCC_DB_PREFIX') ? OCC_DB_PREFIX : ''); } printHeader($hdr,$hdrfn); print '

Step 1 of 5: Enter Database Settings

'; if (!empty($e)) { print '

' . $e . '

'; } print '

valid characters:   a-z   0-9   _   -

may be left blank
 

 

The above information is stored in config.php'; if (defined('OCC_DB_NAME') && (OCC_DB_NAME != '')) { print '.
If you already configured config.php and loaded the schema, you may skip to the next step.'; } print '

'; printFooter(); ?>