}
//
-function install_WriteData ($file, $comment, $prefix, $suffix, $DATA, $SNEAK=0)
-{
- $done = false; $SNEAK++;
- if (file_exists($file))
- {
+function install_WriteData ($file, $comment, $prefix, $suffix, $DATA, $sneak=0) {
+ $done = false; $sneak++;
+ if (file_exists($file)) {
$search = "CFG: ".$comment;
$tmp = $file.".tmp";
$fp = @fopen($file, 'r') or OUTPUT_HTML("<STRONG>READ:</STRONG> ".$file."<BR>");
$line = fgets ($fp, 10240);
if (strpos($line, $search) > -1) $next = 0;
if ($next > -1) {
- if ($next == $SNEAK) {
+ if ($next == $sneak) {
$next = -1;
$line = $prefix.$DATA.$suffix."\n";
} else {
$mysql = "";
if (isset($_POST['mysql']) && is_array($_POST['mysql'])) $mysql = $_POST['mysql'];
-if (URL != "http://your-server.com")
-{
+if (URL != "http://your-server.com") {
// Already installed???
$burl = URL;
-}
- elseif ($burl == "")
-{
+} elseif ($burl == "") {
// Auto-detect URL
$burl = "http://".$SERVER_NAME.$_SERVER['PHP_SELF'];
$burl = substr($burl, 0, strpos($burl, "install.php"));
}
-//
+
+// Check if both passwords from SMTP are matching
+if ((isset($_GET['page']) && ($_GET['page'] == 5))) {
+ // Okay, we have to check it
+ if (!empty($_POST['smtp_user']) && (empty($_POST['smtp_host']))) {
+ // Hostname not set
+ OUTPUT_HTML(INSTALL_SMTP_HOSTNAME_EMPTY."<br />");
+ $_GET['page'] = 3;
+ }
+ if ((empty($_POST['smtp_pass1'])) && (!empty($_POST['smtp_pass2']))) {
+ // Password is empty
+ OUTPUT_HTML(INSTALL_SMTP_PASS1_EMPTY."<br />");
+ $_GET['page'] = 3;
+ }
+ if ((!empty($_POST['smtp_pass1'])) && (empty($_POST['smtp_pass2']))) {
+ // Password repeat is empty
+ OUTPUT_HTML(INSTALL_SMTP_PASS2_EMPTY."<br />");
+ $_GET['page'] = 3;
+ }
+ if ($_POST['smtp_pass1'] != $_POST['smtp_pass1']) {
+ // Passwords are not matching
+ OUTPUT_HTML(INSTALL_SMTP_PASS_MISMATCH."<br />");
+ $_GET['page'] = 3;
+ }
+}
+
+// Is MXChange installed or no admin registered so far?
if ((!mxchange_installed) || (!admin_registered))
{
// Set URL for FORM actions
if (empty($mysql['login'])) $mysql['login'] = "your_login";
if (empty($mysql['host'])) $mysql['host'] = "localhost";
if (empty($mysql['prefix'])) $mysql['prefix'] = "mxchange_";
- if ((sizeof($FATAL) > 0) || (!empty($FATAL[0])))
- {
+ if ((sizeof($FATAL) > 0) || (!empty($FATAL[0]))) {
OUTPUT_HTML("<SPAN class=\"install_fatal\">");
- foreach ($FATAL as $key=>$err)
- {
+ foreach ($FATAL as $key=>$err) {
OUTPUT_HTML(" <STRONG>·</STRONG> ".FATAL_NO.($key + 1).": ".$err."<BR>\n");
}
OUTPUT_HTML("</SPAN><BR>");
LOAD_TEMPLATE("install_page2");
break;
+ case "3":
+ // Set more values
+ define('__SPATH_VALUE' , $_POST['spath']);
+ define('__BURL_VALUE' , $_POST['burl']);
+ define('__TITLE_VALUE' , $_POST['title']);
+ define('__SLOGAN_VALUE' , $_POST['slogan']);
+ define('__EMAIL_VALUE' , $_POST['email']);
+
+ // Use default SMTP data
+ $smtpHost = SMTP_HOSTNAME;
+ $smtpUser = SMTP_USER;
+ $smtpPass1 = SMTP_PASSWORD;
+ $smtpPass2 = SMTP_PASSWORD;
+
+ // Overwrite it with the data from sent (failed) form
+ if (!empty($_POST['smtp_host'])) $smtpHost = $_POST['smtp_host'];
+ if (!empty($_POST['smtp_user'])) $smtpUser = $_POST['smtp_user'];
+
+ // MySQL settings
+ define('__MYSQL_HOST' , $mysql['host']);
+ define('__MYSQL_DBASE' , $mysql['dbase']);
+ define('__MYSQL_PREFIX' , $mysql['prefix']);
+ define('__MYSQL_LOGIN' , $mysql['login']);
+ define('__MYSQL_PASS1' , $mysql['pass1']);
+ define('__MYSQL_PASS2' , $mysql['pass2']);
+
+ // Set constants for SMTP data
+ define('__SMTP_HOST' , $smtpHost);
+ define('__SMTP_USER' , $smtpUser);
+ define('__SMTP_PASS1' , $smtpPass1);
+ define('__SMTP_PASS2' , $smtpPass2);
+
+ // Load template
+ LOAD_TEMPLATE("install_page3");
+ break;
+
case "5": // Misc settings
- define('__SPATH_VALUE' , $_POST['spath']);
- define('__BURL_VALUE' , $_POST['burl']);
- define('__TITLE_VALUE' , $_POST['title']);
- define('__SLOGAN_VALUE', $_POST['slogan']);
- define('__EMAIL_VALUE' , $_POST['email']);
+ // General settings
+ define('__SPATH_VALUE' , $_POST['spath']);
+ define('__BURL_VALUE' , $_POST['burl']);
+ define('__TITLE_VALUE' , $_POST['title']);
+ define('__SLOGAN_VALUE' , $_POST['slogan']);
+ define('__EMAIL_VALUE' , $_POST['email']);
+
+ // MySQL settings
+ define('__MYSQL_HOST' , $mysql['host']);
+ define('__MYSQL_DBASE' , $mysql['dbase']);
+ define('__MYSQL_PREFIX' , $mysql['prefix']);
+ define('__MYSQL_LOGIN' , $mysql['login']);
+
+ // SMTP settings
+ define('__SMTP_HOST' , $_POST['smtp_host']);
+ define('__SMTP_USER' , $_POST['smtp_user']);
+ define('__SMTP_PASS' , $_POST['smtp_pass1']);
OUTPUT_HTML("<FORM action=\"".__BURL_ACTION."/install.php?page=finalize\" method=\"POST\" target=\"_self\">
<TABLE border=\"0\" cellspacing=\"0\" cellpadding=\"0\" class=\"install_content\">
<TR>
</SELECT>
</TD>
</TR>
-<TR><TD colspan=\"2\" height=\"21\" class=\"seperator\"> </TD></TR>
+<TR><TD colspan=\"2\" height=\"10\" class=\"seperator\"> </TD></TR>
<TR>
<TD class=\"install\" align=\"right\">".WARN_NO_PASSWORD.": </TD>
<TD>
</SELECT>
</TD>
</TR>
-<TR><TD colspan=\"2\" height=\"21\" class=\"seperator\"> </TD></TR>
+<TR><TD colspan=\"2\" height=\"10\" class=\"seperator\"> </TD></TR>
<TR>
<TD class=\"install\" align=\"right\">".LANG_WRITE_FOOTER.": </TD>
<TD>
</SELECT>
</TD>
</TR>
-<TR><TD colspan=\"2\" height=\"21\" class=\"seperator\"> </TD></TR>
+<TR><TD colspan=\"2\" height=\"10\" class=\"seperator\"> </TD></TR>
<TR>
<TD class=\"install\" align=\"right\">".LANG_FRAMESET_ACTIVE.": </TD>
<TD>
</SELECT>
</TD>
</TR>
-<TR><TD colspan=\"2\" height=\"21\" class=\"seperator\"> </TD></TR>
+<TR><TD colspan=\"2\" height=\"10\" class=\"seperator\"> </TD></TR>
<TR>
<TD class=\"install\" align=\"right\">".INSTALL_ENABLE_BACKLINK.": </TD>
<TD>
<TR><TD colspan=\"2\" height=\"21\" class=\"seperator\"> </TD></TR>
<TR>
<TD colspan=\"2\" align=\"center\">");
- foreach ($mysql as $key=>$value)
- {
+ foreach ($mysql as $key=>$value) {
OUTPUT_HTML(" <INPUT type=\"hidden\" name=\"mysql[".$key."]\" value=\"".$value."\">");
}
OUTPUT_HTML(" <INPUT type=\"hidden\" name=\"spath\" value=\"".__SPATH_VALUE."\">
<INPUT type=\"hidden\" name=\"title\" value=\"".__TITLE_VALUE."\">
<INPUT type=\"hidden\" name=\"slogan\" value=\"".__SLOGAN_VALUE."\">
<INPUT type=\"hidden\" name=\"email\" value=\"".__EMAIL_VALUE."\">
+ <INPUT type=\"hidden\" name=\"smtp_host\" value=\"".__SMTP_HOST."\">
+ <INPUT type=\"hidden\" name=\"smtp_user\" value=\"".__SMTP_USER."\">
+ <INPUT type=\"hidden\" name=\"smtp_pass\" value=\"".__SMTP_PASS."\">
<INPUT type=\"submit\" class=\"admin_submit submit\" name=\"finalize\" value=\"".NEXT_PAGE."\" class=\"install_submit\">
</TD>
</TR>
break;
case "finalize": // Write captured data to files
- if (!empty($_POST['finalize']))
- {
+ if (!empty($_POST['finalize'])) {
// You have submitted data then we have to reset the fatal messages
$FATAL = array();
// Connect to MySQL server
$link = SQL_CONNECT($mysql['host'], $mysql['login'], $mysql['pass1'], __FILE__, __LINE__);
- if ($link)
- {
+ if ($link) {
// Seems to work, also right database?
$db = SQL_SELECT_DB($mysql['dbase'], $link, __FILE__, __LINE__);
- if ($db)
- {
+ if ($db) {
// Automatically run install.sql
- if (file_exists($_POST['spath']."install/tables.sql"))
- {
+ if (file_exists($_POST['spath']."install/tables.sql")) {
$ERRORS = $_POST['spath']."inc/sql.err";
$cmd = array(
// "Dump" tha' s*** up... ;-) > /dev/null
"mysql ".$mysql['dbase']." --force --host=".$mysql['host']." --user=".$mysql['login']." --password=".$mysql['pass1']." < ".$_POST['spath']."install/menu-".GET_LANGUAGE().".sql"
);
- foreach ($cmd as $c)
- {
+ foreach ($cmd as $c) {
@system($c);
}
- if ((file_exists($ERRORS)) && (filesize($ERRORS) > 0))
- {
+ if ((file_exists($ERRORS)) && (filesize($ERRORS) > 0)) {
ADD_FATAL(MYSQLDUMP_ERROR);
- }
- elseif (!mxchange_installed)
- {
+ } elseif (!mxchange_installed) {
// Remove error file if empty
if (file_exists($ERRORS)) @unlink ($ERRORS);
install_WriteData($_POST['spath']."inc/config.php", "MYSQL-LOGIN", " 'login' => \"", "\",", $mysql['login'], 0);
install_WriteData($_POST['spath']."inc/config.php", "MYSQL-PASSWORD", " 'password' => \"", "\",", $mysql['pass1'], 0);
install_WriteData($_POST['spath']."inc/config.php", "MYSQL-PREFIX", "define ('_MYSQL_PREFIX', \"", "\");", $mysql['prefix'], 0);
+ install_WriteData($_POST['spath']."inc/config.php", "SMTP-HOSTNAME", "define ('SMTP_HOSTNAME', \"", "\");", $_POST['smtp_host'], 0);
+ install_WriteData($_POST['spath']."inc/config.php", "SMTP-USER", "define ('SMTP_USER', \"", "\");", $_POST['smtp_user'], 0);
+ install_WriteData($_POST['spath']."inc/config.php", "SMTP-PASSWORD", "define ('SMTP_PASSWORD', \"", "\");", $_POST['smtp_pass'], 0);
install_WriteData($_POST['spath']."inc/config.php", "INSTALLED", "define ('mxchange_installed', ", ");", "true", 0);
// Close the link
{
$OUT .= " <INPUT type=\"hidden\" name=\"mysql[".$key."]\" value=\"".$value."\">\n";
}
- define('__MYSQL_DATA' , $OUT);
- define('__SPATH_VALUE', $_POST['spath']);
- define('__BURL_VALUE' , $_POST['burl']);
- define('__TITLE_VALUE', $_POST['title']);
+ define('__MYSQL_DATA' , $OUT);
+ define('__SPATH_VALUE' , $_POST['spath']);
+ define('__BURL_VALUE' , $_POST['burl']);
+ define('__TITLE_VALUE' , $_POST['title']);
+ define('__SMTP_HOST' , $_POST['smtp_host']);
+ define('__SMTP_USER' , $_POST['smtp_user']);
+ define('__SMTP_PASS1' , $_POST['smtp_pass1']);
+ define('__SMTP_PASS2' , $_POST['smtp_pass2']);
OUTPUT_HTML("<FORM action=\"".__BURL_ACTION."/install.php?page=2\" method=\"POST\">
<TABLE border=\"0\" cellspacing=\"0\" cellpadding=\"0\" class=\"install_content\">
elseif (mxchange_installed)
{
// Redirection after writing data... :-)
- OUTPUT_HTML("<SPAN class=\"install_finished\">".INSTALL_FINISHED."</SPAN><BR>
-<BR>
-<SPAN class=\"install_security\">".INSTALL_FIN_SECU."</SPAN><BR>
-<BR>
-<FORM action=\"modules.php\" method=\"GET\">
- <INPUT type=\"hidden\" name=\"module\" value=\"admin\">
- <INPUT type=\"submit\" class=\"admin_submit submit\" value=\"".CONTINUE_ADMIN."\" class=\"install_submit\">
-</FORM>");
+ LOAD_TEMPLATE("install_finished");
}
else
{