<?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;

    function show_header($title = "",$nologoutbutton = False, $logoutfrom = "config") 
    {
      global $phpgw_info, $PHP_SELF;
      echo "<html>\n<head>\n";
      echo "  <title>phpGroupWare Setup"; if ($title != ""){echo " - ".$title;}; echo "</title>\n";
      echo "  <style type=\"text/css\"><!-- .link { color: #FFFFFF; } --></style>\n";
      echo "</head>\n";
      echo "<BODY BGCOLOR=\"FFFFFF\" margintop=\"0\" marginleft=\"0\" marginright=\"0\" marginbottom=\"0\">";
      echo "<table border=\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"2\"><tr>";
      echo "  <td align=\"left\" bgcolor=\"486591\">&nbsp;<font color=\"fefefe\">phpGroupWare version ".$phpgw_info["server"]["versions"]["phpgwapi"]." setup</font></td>";
      echo "  <td align=\"right\" bgcolor=\"486591\">";
        if ($nologoutbutton) {
          echo "&nbsp;</td>";
        } else {
          echo "<a href=\"".$PHP_SELF."?FormLogout=".$logoutfrom."\" class=\"link\">Logout</a>&nbsp;</td>";
        }
      echo "</tr></table>";
    }

    function login_form()
    {
     	global $phpgw_info, $phpgw_domain, $PHP_SELF;

      echo "<p><body bgcolor='#ffffff'>\n";
      echo "<table border=\"0\" align=\"center\">\n";
      if ($phpgw_info["setup"]["stage"]["header"] == "10"){
        echo "  <tr bgcolor=\"486591\">\n";
        echo "    <td colspan=\"2\"><font color=\"fefefe\">&nbsp;<b>Setup/Config Admin Login</b></font></td>\n";
        echo "  </tr>\n";
        echo "   <tr bgcolor='#e6e6e6'><td colspan='2'><font color='#ff0000'>".$phpgw_info["setup"]["ConfigLoginMSG"]."</font></td></tr>\n";
        echo "  <tr bgcolor=\"e6e6e6\">\n";
        echo "    <td><form action='index.php' 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=\"ConfigLogin\" value=\"Login\">\n";
        echo "    </form></td>\n";
        echo "  </tr>\n";
      }

      echo "  <tr bgcolor=\"486591\">\n";
      echo "    <td colspan=\"2\"><font color=\"fefefe\">&nbsp;<b>Header Admin Login</b></font></td>\n";
      echo "  </tr>\n";
      echo "   <tr bgcolor=\"#e6e6e6\"><td colspan=\"2\"><font color=\"#ff0000\">".$phpgw_info["setup"]["HeaderLoginMSG"]."</font></td></tr>\n";
      echo "  <tr bgcolor=\"e6e6e6\">\n";
      echo "    <td><form action=\"manageheader.php\" method=\"POST\">\n";
      echo "      <input type=\"password\" name=\"FormPW\" value=\"\">\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")) {
        $phpgw_info["setup"]["header_msg"] = "Stage One";
        return "1";
      }else{
        if (!isset($phpgw_info["server"]["header_admin_password"])){
          $phpgw_info["setup"]["header_msg"] = "Stage One (No header admin password set)";
          return "2";
        }elseif (!isset($phpgw_domain)) {
          $phpgw_info["setup"]["header_msg"] = "Stage One (Upgrade your header.inc.php)";
          return "3";
        }elseif ($phpgw_info["server"]["versions"]["header"] != $phpgw_info["server"]["versions"]["current_header"]) {
          $phpgw_info["setup"]["header_msg"] = "Stage One (Upgrade your header.inc.php)";
          return "3";
        }
      }
      /* header.inc.php part settled. Moving to authentication */
      $phpgw_info["setup"]["header_msg"] = "Stage One (Completed)";
      return "10";
    }
  
    function generate_header()
    {
      global $setting, $phpgw_setup, $phpgw_info, $header_template;
      
      $header_template->set_file(array("header" => "header.inc.php.template"));
      while(list($k,$v) = each($setting)) {
        $header_template->set_var(strtoupper($k),$v);
      }
      return $header_template->parse("out","header");
    }
  
    function auth($auth_type = "Config")
    {
      global $phpgw_domain, $phpgw_info, $HTTP_POST_VARS, $FormLogout, $ConfigLogin, $HeaderLogin, $FormDomain, $FormPW, $ConfigDomain, $ConfigPW, $HeaderPW;
      if (isset($FormLogout)) {
        if ($FormLogout == "config"){
          setcookie("ConfigPW");  // scrub the old one
          setcookie("ConfigDomain");  // scrub the old one
          $phpgw_info["setup"]["ConfigLoginMSG"] = "You have sucessfully logged out";
          return False;
        }elseif($FormLogout == "header"){
          setcookie("HeaderPW");  // scrub the old one
          $phpgw_info["setup"]["HeaderLoginMSG"] = "You have sucessfully logged out";
          return False;
        }
      } elseif (isset($ConfigPW)) {
        if ($ConfigPW != $phpgw_domain[$ConfigDomain]["config_passwd"] && $auth_type == "Config") {
          setcookie("ConfigPW");  // scrub the old one
          setcookie("ConfigDomain");  // scrub the old one
          $phpgw_info["setup"]["ConfigLoginMSG"] = "Invalid session cookie (cookies must be enabled)";
          return False;
        }else{
          return True;
        }
      } elseif (isset($FormPW)) {
        if (isset($ConfigLogin)){
          if ($FormPW == $phpgw_domain[$FormDomain]["config_passwd"] && $auth_type == "Config") {
            setcookie("HeaderPW");  // scrub the old one
            setcookie("ConfigPW",$FormPW);
            setcookie("ConfigDomain",$FormDomain);
            $ConfigDomain = $FormDomain;
            return True;
          }else{
            $phpgw_info["setup"]["ConfigLoginMSG"] = "Invalid password";
            return False;
          }
        }elseif (isset($HeaderLogin)){
          if ($FormPW == $phpgw_info["server"]["header_admin_password"] && $auth_type == "Header") {
            setcookie("HeaderPW",$FormPW);
            return True;
          }else{
            $phpgw_info["setup"]["HeaderLoginMSG"] = "Invalid password";
            return False;
          }
        }
      } elseif (isset($HeaderPW)) {
        if ($HeaderPW != $phpgw_info["server"]["header_admin_password"] && $auth_type == "Header") {
          setcookie("HeaderPW");  // scrub the old one
          $phpgw_info["setup"]["HeaderLoginMSG"] = "Invalid session cookie (cookies must be enabled)";
          return False;
        }else{
          return True;
        }
      } else {
        return False;
      }
    }
  
    function loaddb()
    {
      global $phpgw_info, $phpgw_domain, $ConfigDomain;
      /* Database setup */
      if (!isset($phpgw_info["server"]["api_inc"])) {
        $phpgw_info["server"]["api_inc"] = PHPGW_SERVER_ROOT . "/phpgwapi/inc";
      }
      include($phpgw_info["server"]["api_inc"] . "/class.db_".$phpgw_domain[$ConfigDomain]["db_type"].".inc.php");
      $this->db	          = new db;
      $this->db->Host       = $phpgw_domain[$ConfigDomain]["db_host"];
      $this->db->Type       = $phpgw_domain[$ConfigDomain]["db_type"];
      $this->db->Database   = $phpgw_domain[$ConfigDomain]["db_name"];
      $this->db->User       = $phpgw_domain[$ConfigDomain]["db_user"];
      $this->db->Password   = $phpgw_domain[$ConfigDomain]["db_pass"];

//      $phpgw_schema_proc = new phpgw_schema_proc($phpgw_domain[$ConfigDomain]["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 phpgw_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"]){
            $phpgw_info["setup"]["header_msg"] = "Stage 1 (Tables Complete)";
            return 10;
          }else{
            $phpgw_info["setup"]["header_msg"] = "Stage 1 (Tables need upgrading)";
            return 4;
          }
        }else{
          $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 ($phpgw_info["setup"]["oldver"]["phpgwapi"] != $phpgw_info["server"]["versions"]["phpgwapi"]){
          		return 4;
          } else {
          		$phpgw_info["setup"]["header_msg"] = "Stage 1 (Tables appear to be pre-beta)";
          		return 2;
          }
        }
      }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 )");
        $this->db->query("DROP TABLE phpgw_testrights");
  
        if (isset($db_rights)){
        //if (isset($isdb)){
          $phpgw_info["setup"]["header_msg"] = "Stage 1 (Create tables)";
          return 3;
        }else{
          $phpgw_info["setup"]["header_msg"] = "Stage 1 (Create Database)";
          return 1;
        }
      }
    }

    function check_config()
    {
      global $phpgw_info;
      $this->db->Halt_On_Error = "no";
      if ($phpgw_info["setup"]["stage"]["db"] != 10){return "";}

      // Since 0.9.10pre6 config table is named as phpgw_config
      $config_table="config";
      $ver = explode(".",$phpgw_info["server"]["versions"]["phpgwapi"]);
      if(ereg("([0-9]+)(pre)([0-9]+)",$ver[2],$regs)) 
        if(($regs[1] == "10") && ($regs[3] >= "6"))
	  $config_table="phpgw_config";
      $this->db->query("select config_value from $config_table where config_name='freshinstall'");
      $this->db->next_record();
      $configed = $this->db->f("config_value");
      if ($configed){
        $phpgw_info["setup"]["header_msg"] = "Stage 2 (Needs Configuration)";
        return 1;
      }else{
        $phpgw_info["setup"]["header_msg"] = "Stage 2 (Configuration OK)";
        return 10;
      }
      
    }

    function check_lang()
    {
      global $phpgw_info;
      $this->db->Halt_On_Error = "no";
      if ($phpgw_info["setup"]["stage"]["db"] != 10){return "";}
            
      $this->db->query("select distinct lang from lang;");
      if ($this->db->num_rows() == 0){
        $phpgw_info["setup"]["header_msg"] = "Stage 3 (No languages installed)";
        return 1;
      }else{
        while (@$this->db->next_record()) {
          $phpgw_info["setup"]["installed_langs"][$this->db->f("lang")] = $this->db->f("lang");
        }
        reset ($phpgw_info["setup"]["installed_langs"]);
        while (list ($key, $value) = each ($phpgw_info["setup"]["installed_langs"])) {
          $sql = "select lang_name from languages where lang_id = '".$value."';";
          $this->db->query($sql);
          $this->db->next_record();
          $phpgw_info["setup"]["installed_langs"][$value] = $this->db->f("lang_name");
        }
        $phpgw_info["setup"]["header_msg"] = "Stage 3 (Completed)";
        return 10;
      }
    }

    function get_template_list(){
      global $phpgw_info;
      $d = dir(PHPGW_SERVER_ROOT."/phpgwapi/templates");
      $list["user_choice"]["name"] = "user_choice";
      $list["user_choice"]["title"] = "Users Choice";
      while($entry=$d->read()) {
        if ($entry != "CVS" && $entry != "." && $entry != ".."){
          $list[$entry]["name"] = $entry;
          $f = PHPGW_SERVER_ROOT."/phpgwapi/templates/".$entry."/details.inc.php";
          if (file_exists ($f)){
            include($f);
            $list[$entry]["title"] = "Use ".$phpgw_info["template"][$entry]["title"]."interface";
          }else{
            $list[$entry]["title"] = $entry;
          }
        }
      }
      $d->close();
      reset ($list);
      return $list;
    }
  
    function app_setups($appname = ""){
      global $phpgw_info;
      $d = dir(PHPGW_SERVER_ROOT);
      while($entry=$d->read()) {
        if (is_dir (PHPGW_SERVER_ROOT."/".$entry."/setup")){
          echo $entry."<br>\n";
        }
      }
      $d->close();
    }

    function app_status($appname = ""){
      global $phpgw_info;
      $this->get_versions();
      reset ($phpgw_info['server']['versions']);

      $this->db->query("select * from phpgw_applications");
      while ($this->db->next_record()){
        $phpgw_info['server']['current_versions'][$this->db->f('app_name')] = $this->db->f('app_version');
      }
      while (list($key, $value) = each ($phpgw_info['server']['versions'])){
        if ($key != 'header' && $key != 'current_header' && $key != '' && $key != 'mcrypt'){
          if (!isset($phpgw_info['server']['current_versions'][$key])){
            $phpgw_info['server']['current_versions'][$key] = 'new';
            $phpgw_info['setup'][$key]['status'] = 'new';
          }elseif ($value != $phpgw_info['server']['current_versions'][$key]){
              $phpgw_info['setup'][$key]['status'] = 'upgrade';
          }else{
              $phpgw_info['setup'][$key]['status'] = 'current';
          }
          echo 'phpgw_info[setup][$key][status]: '.$phpgw_info['setup'][$key]['status'].'<br>';
        }
      }

    }
  
    function execute_script($script, $order = ""){
      global $phpgw_info, $phpgw_domain, $current_config, $newsetting, $phpgw_setup, $SERVER_NAME;
      if ($order != "" && gettype($order) != "array"){ $order = array($order); }
      if ($order == ""){$order = array();}
      /* First include the ordered setup script file */
      reset ($order);
      while (list (, $appname) = each ($order)){
        $f = PHPGW_SERVER_ROOT."/".$appname."/setup/".$script.".inc.php";
    	  if (file_exists($f)) {include($f);}
        $completed_scripts[$appname] = True;
      }
      /* Then add the rest */
      $d = dir(PHPGW_SERVER_ROOT);
      while ($entry=$d->read()){
        if ($entry != "" && $completed_scripts[$entry] != True){
          $f = PHPGW_SERVER_ROOT."/".$entry."/setup/".$script.".inc.php";
      	  if (file_exists($f)) {include($f);}
        }
      }
    }
  
    function get_versions(){
      global $phpgw_info, $phpgw_domain, $current_config, $newsetting, $phpgw_setup, $SERVER_NAME;
      $d = dir(PHPGW_SERVER_ROOT);
      while($entry=$d->read()) {
        $f = PHPGW_SERVER_ROOT."/".$entry."/version.inc.php";
        if (file_exists ($f)){include($f); }
      }
      $d->close();
    }

    function update_app_version($appname, $tableschanged = True){
      global $phpgw_info;
      if ($tableschanged == True){$phpgw_info["setup"]["tableschanged"] = True;}
      $this->db->query("update phpgw_applications set app_version='".$phpgw_info["setup"]["currentver"]["phpgwapi"]."' where app_name='".$appname."'");
    }
  
    function manage_tables($appname=""){
      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";
      }
      */
    }
  }
?>