added mutli-domain support. Still have a bug when going to the config page. It will not work for one of my test domains, and Im not sure why

This commit is contained in:
seek3r 2000-11-19 10:49:31 +00:00
parent 561deb921c
commit 36f7b3e13b
3 changed files with 79 additions and 44 deletions

View File

@ -25,11 +25,19 @@
include($phpgw_info["server"]["api_dir"] . "/phpgw_db_".$phpgw_info["server"]["db_type"].".inc.php"); include($phpgw_info["server"]["api_dir"] . "/phpgw_db_".$phpgw_info["server"]["db_type"].".inc.php");
$db = new db; $db = new db;
if ($phpgw_info["multiable_domains"] != True){
$db->Host = $phpgw_info["server"]["db_host"]; $db->Host = $phpgw_info["server"]["db_host"];
$db->Type = $phpgw_info["server"]["db_type"]; $db->Type = $phpgw_info["server"]["db_type"];
$db->Database = $phpgw_info["server"]["db_name"]; $db->Database = $phpgw_info["server"]["db_name"];
$db->User = $phpgw_info["server"]["db_user"]; $db->User = $phpgw_info["server"]["db_user"];
$db->Password = $phpgw_info["server"]["db_pass"]; $db->Password = $phpgw_info["server"]["db_pass"];
}else{
$db->Host = $domains[$SetupDomain]["db_host"];
$db->Type = $domains[$SetupDomain]["db_type"];
$db->Database = $domains[$SetupDomain]["db_name"];
$db->User = $domains[$SetupDomain]["db_user"];
$db->Password = $domains[$SetupDomain]["db_pass"];
}
if ($newsettings["auth_type"] != "ldap") { if ($newsettings["auth_type"] != "ldap") {
setup_header(); setup_header();

View File

@ -27,7 +27,7 @@
function loginForm($err="") function loginForm($err="")
{ {
global $PHP_SELF; global $phpgw_info, $domain, $PHP_SELF;
setup_header("Please login"); setup_header("Please login");
@ -42,8 +42,8 @@
echo " <tr bgcolor=\"e6e6e6\">\n"; echo " <tr bgcolor=\"e6e6e6\">\n";
echo " <td><form action='".$PHP_SELF."' method='POST'>\n"; echo " <td><form action='".$PHP_SELF."' method='POST'>\n";
if ($phpgw_info["multiable_domains"] == True){ if ($phpgw_info["multiable_domains"] == True){
echo " <input type='text' name='domain' value=''><br>\n"; echo " <table><tr><td>Domain: </td><td><input type='text' name='domain' value=''></td></tr>\n";
echo " <input type='password' name='FormPW' value=''><br>\n"; echo " <tr><td>Password: </td><td><input type='password' name='FormPW' value=''></td></tr></table>\n";
}else{ }else{
echo " <input type='password' name='FormPW' value=''>\n"; echo " <input type='password' name='FormPW' value=''>\n";
} }
@ -55,18 +55,34 @@
} }
if (isset($FormPW)) { if (isset($FormPW)) {
if ($phpgw_info["multiable_domains"] == True){
if ($FormPW != $domains[$domain]["config_passwd"]) {
loginForm("Invalid password.");
exit;
}
}else{
if ($FormPW != $phpgw_info["server"]["config_passwd"]) { if ($FormPW != $phpgw_info["server"]["config_passwd"]) {
loginForm("Invalid password."); loginForm("Invalid password.");
exit; exit;
} }
}
// Valid login, fall through and set the cookie // Valid login, fall through and set the cookie
$SetupCookie = $FormPW; $SetupCookie = $FormPW;
} else if (isset($SetupCookie)) { } else if (isset($SetupCookie)) {
if ($phpgw_info["multiable_domains"] == True){
if ($SetupCookie != $domains[$SetupDomain]["config_passwd"]) {
setcookie("SetupCookie",""); // scrub the old one
setcookie("SetupDomain",""); // scrub the old one
loginForm("Invalid session cookie (cookies must be enabled)");
exit;
}
}else{
if ($SetupCookie != $phpgw_info["server"]["config_passwd"]) { if ($SetupCookie != $phpgw_info["server"]["config_passwd"]) {
setcookie("SetupCookie",""); // scrub the old one setcookie("SetupCookie",""); // scrub the old one
loginForm("Invalid session cookie (cookies must be enabled)"); loginForm("Invalid session cookie (cookies must be enabled)");
exit; exit;
} }
}
} else { } else {
loginForm(); loginForm();
exit; exit;
@ -74,4 +90,7 @@
// Auth ok. // Auth ok.
setcookie("SetupCookie","$SetupCookie"); setcookie("SetupCookie","$SetupCookie");
if ($phpgw_info["multiable_domains"] == True){
setcookie("SetupDomain","$domain");
}
?> ?>

View File

@ -42,11 +42,19 @@
} }
$db = new db; $db = new db;
if ($phpgw_info["multiable_domains"] != True){
$db->Host = $phpgw_info["server"]["db_host"]; $db->Host = $phpgw_info["server"]["db_host"];
$db->Type = $phpgw_info["server"]["db_type"]; $db->Type = $phpgw_info["server"]["db_type"];
$db->Database = $phpgw_info["server"]["db_name"]; $db->Database = $phpgw_info["server"]["db_name"];
$db->User = $phpgw_info["server"]["db_user"]; $db->User = $phpgw_info["server"]["db_user"];
$db->Password = $phpgw_info["server"]["db_pass"]; $db->Password = $phpgw_info["server"]["db_pass"];
}else{
$db->Host = $domains[$SetupDomain]["db_host"];
$db->Type = $domains[$SetupDomain]["db_type"];
$db->Database = $domains[$SetupDomain]["db_name"];
$db->User = $domains[$SetupDomain]["db_user"];
$db->Password = $domains[$SetupDomain]["db_pass"];
}
// $db->Halt_On_Error = "report"; // $db->Halt_On_Error = "report";
$db->Halt_On_Error = "no"; $db->Halt_On_Error = "no";