forked from extern/egroupware
359 lines
14 KiB
PHP
359 lines
14 KiB
PHP
<?php
|
|
/**************************************************************************\
|
|
* phpGroupWare - Setup *
|
|
* http://www.phpgroupware.org *
|
|
* -------------------------------------------- *
|
|
* This program is free software; you can redistribute it and/or modify it *
|
|
* under the terms of the GNU General Public License as published by the *
|
|
* Free Software Foundation; either version 2 of the License, or (at your *
|
|
* option) any later version. *
|
|
\**************************************************************************/
|
|
|
|
/* $Id$ */
|
|
|
|
class phpgw_setup
|
|
{
|
|
var $db;
|
|
var $template;
|
|
|
|
function show_header($title = "",$nologoutbutton = False)
|
|
{
|
|
global $phpgw_info, $PHP_SELF;
|
|
echo '
|
|
<html>
|
|
<head>
|
|
<title>phpGroupWare Setup';
|
|
if ($title != ""){echo " - ".$title;}
|
|
echo'</title>
|
|
<style type="text/css"><!-- .link { color: #FFFFFF; } --></style>
|
|
</head>
|
|
<BODY BGCOLOR="FFFFFF" margintop="0" marginleft="0" marginright="0" marginbottom="0">
|
|
<table border="0" width="100%" cellspacing="0" cellpadding="2">
|
|
<tr>
|
|
<td align="left" bgcolor="486591"> <font color="fefefe">phpGroupWare version '.$phpgw_info["server"]["versions"]["phpgwapi"].' setup</font>
|
|
</td>
|
|
<td align="right" bgcolor="486591">';
|
|
if ($nologoutbutton) {
|
|
echo " ";
|
|
} else {
|
|
echo '<a href="' . $PHP_SELF . '?FormLogout=True" class="link">Logout</a> ';
|
|
}
|
|
echo "</td></tr></table>";
|
|
}
|
|
function loginForm($login_msg="", $header_login_msg="")
|
|
{
|
|
global $phpgw_info, $phpgw_domain, $SetupDomain, $SetupPW, $PHP_SELF;
|
|
echo "<p><body bgcolor='#ffffff'>\n";
|
|
echo "<table border=\"0\" align=\"center\">\n";
|
|
if ( $phpgw_info["setup"]["stage"] >= 1.4){
|
|
echo " <tr bgcolor=\"486591\">\n";
|
|
echo " <td colspan=\"2\"><font color=\"fefefe\"> <b>Setup/Config Admin Login</b></font></td>\n";
|
|
echo " </tr>\n";
|
|
if ($err != "") {
|
|
echo " <tr bgcolor='#e6e6e6'><td colspan='2'><font color='#ff0000'>".$login_msg."</font></td></tr>\n";
|
|
}
|
|
echo " <tr bgcolor=\"e6e6e6\">\n";
|
|
echo " <td><form action='".$PHP_SELF."' method='POST'>\n";
|
|
if (count($phpgw_domain) > 1){
|
|
echo " <table><tr><td>Domain: </td><td><input type='text' name='FormDomain' value=''></td></tr>\n";
|
|
echo " <tr><td>Password: </td><td><input type='password' name='FormPW' value=''></td></tr></table>\n";
|
|
}else{
|
|
reset($phpgw_domain);
|
|
$default_domain = each($phpgw_domain);
|
|
echo " <input type='password' name='FormPW' value=''>\n";
|
|
echo " <input type='hidden' name='FormDomain' value='".$default_domain[0]."'>\n";
|
|
}
|
|
echo " <input type='submit' name='Login' value='Login'>\n";
|
|
echo " </form></td>\n";
|
|
echo " </tr>\n";
|
|
}
|
|
|
|
echo " <tr bgcolor=\"486591\">\n";
|
|
echo " <td colspan=\"2\"><font color=\"fefefe\"> <b>Header Admin Login</b></font></td>\n";
|
|
echo " </tr>\n";
|
|
if ($err != "") {
|
|
echo " <tr bgcolor='#e6e6e6'><td colspan='2'><font color='#ff0000'>".$header_login_msg."</font></td></tr>\n";
|
|
}
|
|
echo " <tr bgcolor=\"e6e6e6\">\n";
|
|
echo " <td><form action='createheader.php' method='POST'>\n";
|
|
echo " <input type='password' name='HeaderPW' value='changethis'>\n";
|
|
echo " <input type='submit' name='HeaderLogin' value='Login'>\n";
|
|
echo " </form></td>\n";
|
|
echo " </tr>\n";
|
|
|
|
echo "</table>\n";
|
|
echo "</body></html>\n";
|
|
}
|
|
|
|
function check_header()
|
|
{
|
|
global $phpgw_domain, $phpgw_info;
|
|
if(!file_exists("../header.inc.php") || !is_file("../header.inc.php")) {
|
|
$phpgw_info["setup"]["stage"] = 1.1;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage One";
|
|
}else{
|
|
include("../header.inc.php");
|
|
if (!isset($phpgw_info["server"]["header_admin_password"])){
|
|
$phpgw_info["setup"]["stage"] = 1.2;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage One (No header admin password set)";
|
|
}elseif (!isset($phpgw_domain) || $phpgw_info["server"]["versions"]["header"] != $phpgw_info["server"]["versions"]["current_header"]) {
|
|
$phpgw_info["setup"]["stage"] = 1.3;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage One (Upgrade your header.inc.php)";
|
|
}else{ /* header.inc.php part settled. Moving to authentication */
|
|
$phpgw_info["setup"]["stage"] = 1.4;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage One (Completed)";
|
|
}
|
|
}
|
|
}
|
|
|
|
function generate_header()
|
|
{
|
|
global $setting, $phpgw_setup;
|
|
|
|
$phpgw_setup->template->set_file(array("header" => "header.inc.php.template"));
|
|
while(list($k,$v) = each($setting)) {
|
|
$phpgw_setup->template->set_var(strtoupper($k),$v);
|
|
}
|
|
return $phpgw_setup->template->parse("out","header");
|
|
}
|
|
|
|
function config_auth()
|
|
{
|
|
global $phpgw_domain, $FormLogout, $FormDomain, $FormHeaderPW, $FormPW, $SetupDomain, $HTTP_POST_VARS, $login_msg;
|
|
if (isset($FormLogout)) {
|
|
setcookie("SetupPW"); // scrub the old one
|
|
setcookie("SetupDomain"); // scrub the old one
|
|
setcookie("HeaderPW"); // scrub the old one
|
|
$login_msg = "You have sucessfully logged out";
|
|
return False;
|
|
} elseif (isset($SetupPW)) {
|
|
if ($SetupPW != $phpgw_domain[$SetupDomain]["config_passwd"]) {
|
|
setcookie("SetupPW"); // scrub the old one
|
|
setcookie("SetupDomain"); // scrub the old one
|
|
$login_msg = "Invalid session cookie (cookies must be enabled)";
|
|
return False;
|
|
}else{
|
|
return True;
|
|
}
|
|
} elseif (isset($FormPW)) {
|
|
if ($FormPW == $phpgw_domain[$FormDomain]["config_passwd"]) {
|
|
setcookie("SetupPW",$FormPW);
|
|
setcookie("SetupDomain",$FormDomain);
|
|
$SetupDomain = $FormDomain;
|
|
return True;
|
|
}else{
|
|
$login_msg = "Invalid password";
|
|
return False;
|
|
}
|
|
} else {
|
|
return False;
|
|
}
|
|
}
|
|
|
|
function header_auth()
|
|
{
|
|
global $phpgw_domain, $FormHeaderPW, $FormHeaderLogout,$HTTP_POST_VARS, $header_login_msg;
|
|
if (isset($FormHeaderLogout)) {
|
|
setcookie("HeaderPW"); // scrub the old one
|
|
$header_login_msg = "You have sucessfully logged out";
|
|
return False;
|
|
} elseif (isset($HeaderPW)) {
|
|
if ($HeaderPW != $phpgw_info["server"]["header_admin_password"]) {
|
|
setcookie("SetupPW"); // scrub the old one
|
|
setcookie("SetupDomain"); // scrub the old one
|
|
setcookie("HeaderPW"); // scrub the old one
|
|
$header_login_msg = "Invalid session cookie (cookies must be enabled)";
|
|
return False;
|
|
}else{
|
|
return True;
|
|
}
|
|
} elseif (isset($FormHeaderPW)) {
|
|
if ($FormHeaderPW == $phpgw_info["server"]["header_admin_password"]) {
|
|
setcookie("HeaderPW",$HeaderPW);
|
|
return True;
|
|
}else{
|
|
$header_login_msg = "Invalid password";
|
|
return False;
|
|
}
|
|
} else {
|
|
return False;
|
|
}
|
|
}
|
|
|
|
|
|
function loaddb()
|
|
{
|
|
global $phpgw_info, $phpgw_domain, $SetupDomain;
|
|
/* Database setup */
|
|
if (!isset($phpgw_info["server"]["api_inc"])) {
|
|
$phpgw_info["server"]["api_inc"] = $phpgw_info["server"]["server_root"]."/phpgwapi/inc";
|
|
}
|
|
include($phpgw_info["server"]["api_inc"] . "/phpgw_db_".$phpgw_domain[$SetupDomain]["db_type"].".inc.php");
|
|
$this->db = new db;
|
|
$this->db->Host = $phpgw_domain[$SetupDomain]["db_host"];
|
|
$this->db->Type = $phpgw_domain[$SetupDomain]["db_type"];
|
|
$this->db->Database = $phpgw_domain[$SetupDomain]["db_name"];
|
|
$this->db->User = $phpgw_domain[$SetupDomain]["db_user"];
|
|
$this->db->Password = $phpgw_domain[$SetupDomain]["db_pass"];
|
|
|
|
$phpgw_schema_proc = new phpgw_schema_proc($phpgw_domain[$SetupDomain]["db_type"]);
|
|
}
|
|
|
|
function check_db()
|
|
{
|
|
global $phpgw_info;
|
|
$this->db->Halt_On_Error = "no";
|
|
$tables = $this->db->table_names();
|
|
if (is_array($tables) && count($tables) > 0){
|
|
/* tables exists. checking for post beta version */
|
|
$this->db->query("select * from applications");
|
|
while (@$this->db->next_record()) {
|
|
if ($this->db->f("app_name") == "admin"){$phpgw_info["setup"]["oldver"]["phpgwapi"] = $this->db->f("app_version");}
|
|
$phpgw_info["setup"]["oldver"][$this->db->f("app_name")] = $this->db->f("app_version");
|
|
$phpgw_info["setup"][$this->db->f("app_name")]["title"] = $this->db->f("app_title");
|
|
}
|
|
if (isset($phpgw_info["setup"]["oldver"]["phpgwapi"])){
|
|
if ($phpgw_info["setup"]["oldver"]["phpgwapi"] == $phpgw_info["server"]["versions"]["phpgwapi"]){
|
|
$this->db->query("select config_value from config where config_name='freshinstall'");
|
|
$this->db->next_record();
|
|
$configed = $this->db->f("config_value");
|
|
if ($configed){
|
|
$phpgw_info["setup"]["stage"] = 3.1;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage 3 (Needs Configuration)";
|
|
}else{
|
|
$phpgw_info["setup"]["stage"] = 3.2;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage 3 (Configuration OK)";
|
|
}
|
|
}else{
|
|
$phpgw_info["setup"]["stage"] = 2.4;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage 2 (Tables need upgrading)";
|
|
}
|
|
}else{
|
|
$phpgw_info["setup"]["stage"] = 2.2;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage 2 (Tables appear to be pre-beta)";
|
|
}
|
|
}else{
|
|
/* no tables, so checking if we can create them */
|
|
|
|
/* I cannot get either to work properly
|
|
$isdb = $this->db->connect("kljkjh", "localhost", "phpgroupware", "phpgr0upwar3");
|
|
*/
|
|
|
|
$db_rights = $this->db->query("CREATE TABLE phpgw_testrights ( testfield varchar(5) NOT NULL )");
|
|
|
|
if (isset($db_rights)){
|
|
//if (isset($isdb)){
|
|
$phpgw_info["setup"]["stage"] = 2.3;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage 2 (Create tables)";
|
|
}else{
|
|
$phpgw_info["setup"]["stage"] = 2.1;
|
|
$phpgw_info["setup"]["header_msg"] = "Stage 2 (Create Database)";
|
|
}
|
|
$this->db->query("DROP TABLE phpgw_testrights");
|
|
}
|
|
}
|
|
|
|
function app_setups($appname = ""){
|
|
global $phpgw_info;
|
|
$d = dir($phpgw_info["server"]["server_root"]);
|
|
while($entry=$d->read()) {
|
|
if (is_dir ($phpgw_info["server"]["server_root"]."/".$entry."/setup")){
|
|
echo $entry."<br>\n";
|
|
}
|
|
}
|
|
$d->close();
|
|
}
|
|
|
|
function execute_script($script, $appname = ""){
|
|
global $phpgw_info, $phpgw_domain;
|
|
if ($appname == ""){
|
|
$d = dir($phpgw_info["server"]["server_root"]);
|
|
while($entry=$d->read()) {
|
|
$f = $phpgw_info["server"]["server_root"]."/".$entry."/setup/version.inc.php";
|
|
if (file_exists ($f)){
|
|
include($f);
|
|
}else{
|
|
$phpgw_info["server"]["versions"][$entry] = $phpgw_info["setup"]["currentver"]["phpgwapi"];
|
|
}
|
|
|
|
$f = $phpgw_info["server"]["server_root"]."/".$entry."/setup/".$script.".inc.php";
|
|
if (file_exists ($f)){include($f);}
|
|
}
|
|
$d->close();
|
|
}else{
|
|
$f = $phpgw_info["server"]["server_root"]."/".$appname."/setup/".$script.".inc.php";
|
|
if (file_exists ($f)){include($f);}
|
|
}
|
|
}
|
|
|
|
function update_app_version($appname, $tableschanged = True){
|
|
global $phpgw_info;
|
|
if ($tableschanged == True){$phpgw_info["setup"]["tableschanged"] = True;}
|
|
$this->db->query("update applications set app_version='".$phpgw_info["setup"]["currentver"]["phpgwapi"]."' where app_name='".$appname."'");
|
|
}
|
|
|
|
function manage_tables(){
|
|
global $phpgw_domain, $phpgw_info;
|
|
if ($phpgw_info["setup"]["currentver"]["phpgwapi"] == "drop"){
|
|
$this->execute_script("droptables");
|
|
}
|
|
if ($phpgw_info["setup"]["currentver"]["phpgwapi"] == "new") {
|
|
$this->execute_script("newtables");
|
|
$this->execute_script("common_default_records");
|
|
$this->execute_script("lang");
|
|
}
|
|
|
|
if ($phpgw_info["setup"]["currentver"]["phpgwapi"] == "oldversion") {
|
|
$phpgw_info["setup"]["currentver"]["phpgwapi"] = $phpgw_info["setup"]["oldver"]["phpgwapi"];
|
|
$this->execute_script("upgradetables");
|
|
}
|
|
|
|
/* Not yet implemented
|
|
if (!$phpgw_info["setup"]["tableschanged"] == True){
|
|
echo " <tr bgcolor=\"e6e6e6\">\n";
|
|
echo " <td>No table changes were needed. The script only updated your version setting.</td>\n";
|
|
echo " </tr>\n";
|
|
}
|
|
*/
|
|
}
|
|
|
|
function setup_header($title = "",$nologoutbutton = False) {
|
|
global $phpgw_info, $PHP_SELF;
|
|
|
|
// Ok, so it isn't the greatest idea, but it works for now. Setup needs to be rewritten.
|
|
if ($phpgw_info["setup"]["dontshowtheheaderagain"]) {
|
|
return False;
|
|
}
|
|
|
|
$phpgw_info["setup"]["dontshowtheheaderagain"] = True;
|
|
?>
|
|
|
|
<head>
|
|
<title>phpGroupWare setup <?php echo $title; ?></title>
|
|
<style type="text/css">
|
|
<!--
|
|
.link
|
|
{
|
|
color: #FFFFFF;
|
|
}
|
|
-->
|
|
</style>
|
|
</head>
|
|
<BODY BGCOLOR="FFFFFF" margintop="0" marginleft="0" marginright="0" marginbottom="0">
|
|
<table border="0" width="100%" cellspacing="0" cellpadding="2">
|
|
<tr>
|
|
<td align="left" bgcolor="486591"> <font color="fefefe">phpGroupWare version <?php
|
|
echo $phpgw_info["server"]["versions"]["phpgwapi"]; ?> setup</font>
|
|
</td>
|
|
<td align="right" bgcolor="486591">
|
|
<?php
|
|
if ($nologoutbutton) {
|
|
echo " ";
|
|
} else {
|
|
echo '<a href="' . $PHP_SELF . '?FormLogout=True" class="link">Logout</a> ';
|
|
}
|
|
|
|
echo "</td></tr></table>";
|
|
}
|
|
}
|
|
?>
|