tbrehm
2007-08-11 ce95440aa1c20dd7aa169d9ac8b1d5db3889b467
install/lib/installer_base.lib.php
@@ -38,13 +38,63 @@
   
   */
   
   function lng() {
   function lng($text) {
      return $text;
   }
   
   function error($msg) {
      die("ERROR: ".$msg."\n");
   }
   function simple_query($query,$answers,$default) {
      global $conf;
      $finished = false;
      do {
         $answers_str = implode(",",$answers);
         swriteln($this->lng($query).' ('.$answers_str.') ['.$default.']:');
         $input = sread();
         // Stop the installation
         if($input == 'quit') {
            die($this->lng('Installation interrupted.'));
         }
         // Select the default
         if($input == '') {
            $answer = $default;
            $finished = true;
         }
         if(in_array($input,$answers)) {
            $answer = $input;
            $finished = true;
         }
      } while ($finished == false);
      return $answer;
   }
   function free_query($query,$default) {
      global $conf;
      $answers_str = implode(",",$answers);
      swriteln($this->lng($query).' ['.$default.']:');
      $input = sread();
      // Stop the installation
      if($input == 'quit') {
         die($this->lng('Installation interrupted.'));
      }
      // Select the default
      if($input == '') {
         $answer = $default;
      }
      return $answer;
   }
   
   function request_language() {
      
@@ -104,7 +154,7 @@
      Create postfix configuration files
   */
   
   function configure_postfix() {
   function configure_postfix($options = '') {
      global $conf;
      
      if(!is_dir($conf["dist_postfix_config_dir"])) $this->error("The postfix configuration directory ".$conf["dist_postfix_config_dir"]." does not exist.");
@@ -248,13 +298,14 @@
  flags=R user=vmail argv=/usr/bin/maildrop -d ${recipient} ${extension} ${recipient} ${user} ${nexthop} ${sender}
      
      */
      if(!stristr($options,'dont-create-certs')) {
         // Create the SSL certificate
         $command = "cd ".$conf["dist_postfix_config_dir"]."; openssl req -new -outform PEM -out smtpd.cert -newkey rsa:2048 -nodes -keyout smtpd.key -keyform PEM -days 365 -x509";
         exec($command);
      
      // Create the SSL certificate
      $command = "cd ".$conf["dist_postfix_config_dir"]."; openssl req -new -outform PEM -out smtpd.cert -newkey rsa:2048 -nodes -keyout smtpd.key -keyform PEM -days 365 -x509";
      exec($command);
      $command = "chmod o= ".$conf["dist_postfix_config_dir"]."/smtpd.key";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
         $command = "chmod o= ".$conf["dist_postfix_config_dir"]."/smtpd.key";
         caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
      }
      
      /*
      We have to change the permissions of the courier authdaemon directory
@@ -263,6 +314,14 @@
      
      $command = "chmod 755  /var/run/courier/authdaemon/";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
      // Changing maildrop lines in posfix master.cf
      if(is_file($conf["dist_postfix_config_dir"].'/master.cf')) copy($conf["dist_postfix_config_dir"].'/master.cf',$conf["dist_postfix_config_dir"].'/master.cf~');
      if(is_file($conf["dist_postfix_config_dir"].'/master.cf~')) exec('chmod 400 '.$conf["dist_postfix_config_dir"].'/master.cf~');
      $configfile = $conf["dist_postfix_config_dir"].'/master.cf';
      $content = rf($configfile);
      $content = str_replace('  flags=DRhu user=vmail argv=/usr/bin/maildrop -d ${recipient}','  flags=R user='.$conf["dist_postfix_vmail_username"].' argv=/usr/bin/maildrop -d ${recipient} ${extension} ${recipient} ${user} ${nexthop} ${sender}',$content);
      wf($configfile,$content);
      
      // Writing the Maildrop mailfilter file
      $configfile = 'mailfilter';
@@ -289,47 +348,7 @@
   function configure_saslauthd() {
      global $conf;
      
      /*
      TODO: The example below is for Ubuntu 6.10
      mkdir -p /var/spool/postfix/var/run/saslauthd
Edit /etc/default/saslauthd. Remove the # in front of START=yes and add the line PARAMS="-m /var/spool/postfix/var/run/saslauthd -r".
vi /etc/default/saslauthd
The file should then look like this:
# This needs to be uncommented before saslauthd will be run automatically
START=yes
# You must specify the authentication mechanisms you wish to use.
# This defaults to "pam" for PAM support, but may also include
# "shadow" or "sasldb", like this:
# MECHANISMS="pam shadow"
MECHANISMS="pam"
PARAMS="-m /var/spool/postfix/var/run/saslauthd -r"
We must also edit /etc/init.d/saslauthd and change the location of saslauthd's PID file.
vi /etc/init.d/saslauthd
Change the value of PIDFILE to /var/spool/postfix/var/run/${NAME}/saslauthd.pid:
PIDFILE="/var/spool/postfix/var/run/${NAME}/saslauthd.pid"
Then restart Postfix and Saslauthd:
/etc/init.d/postfix restart
postfix check
/etc/init.d/saslauthd restart
      */
      $configfile = 'sasl_smtpd.conf';
      if(is_file($conf["dist_postfix_config_dir"].'/sasl/smtpd.conf')) copy($conf["dist_postfix_config_dir"].'/sasl/smtpd.conf',$conf["dist_postfix_config_dir"].'/sasl/smtpd.conf~');
      if(is_file($conf["dist_postfix_config_dir"].'/sasl/smtpd.conf~')) exec('chmod 400 '.$conf["dist_postfix_config_dir"].'/sasl/smtpd.conf~');
@@ -341,6 +360,26 @@
      wf($conf["dist_postfix_config_dir"].'/sasl/smtpd.conf',$content);
      
      // TODO: Chmod and chown on the config file
      // Create the spool directory
      exec("mkdir -p /var/spool/postfix/var/run/saslauthd");
      // Edit the file /etc/default/saslauthd
      $configfile = '/etc/default/saslauthd';
      if(is_file($configfile)) copy($configfile,$configfile.'~');
      if(is_file($configfile.'~')) exec('chmod 400 '.$configfile.'~');
      $content = rf($configfile);
      $content = str_replace('START=no','START=yes',$content);
      $content = str_replace('OPTIONS="-c"','OPTIONS="-m /var/spool/postfix/var/run/saslauthd -r"',$content);
      wf($configfile,$content);
      // Edit the file /etc/default/saslauthd
      $configfile = '/etc/init.d/saslauthd';
      $content = rf($configfile);
      $content = str_replace('PIDFILE=$RUN_DIR/saslauthd.pid','PIDFILE="/var/spool/postfix/var/run/${NAME}/saslauthd.pid"',$content);
      wf($configfile,$content);
      
      
   }
@@ -379,6 +418,16 @@
      
      exec('chmod 660 '.$conf["dist_courier_config_dir"].'/'.$configfile);
      exec('chown daemon:daemon '.$conf["dist_courier_config_dir"].'/'.$configfile);
      //authdaemonrc
      $configfile = $conf["dist_courier_config_dir"].'/authdaemonrc';
      if(is_file($configfile)) copy($configfile,$configfile.'~');
      if(is_file($configfile.'~')) exec('chmod 400 '.$configfile.'~');
      $content = rf($configfile);
      $content = str_replace('authmodulelist="authpam"','authmodulelist="authmysql"',$content);
      wf($configfile,$content);
   }
   
   function configure_amavis() {
@@ -439,6 +488,60 @@
      wf($configfile,$content);
   }
   
   function configure_getmail() {
      global $conf;
      $command = "useradd -d /etc/getmail getmail";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
      $command = "chown -R getmail /etc/getmail";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
      $command = "chmod -R 700 /etc/getmail";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
   }
   function configure_pureftpd() {
      global $conf;
      // configure pam for SMTP authentication agains the ispconfig database
      $configfile = 'mysql.conf';
      if(is_file($conf["dist_pureftpd_config_dir"].'/'.$configfile)) copy($conf["dist_pureftpd_config_dir"].'/'.$configfile,$conf["dist_pureftpd_config_dir"].'/'.$configfile.'~');
      if(is_file($conf["dist_pureftpd_config_dir"].'/'.$configfile.'~')) exec('chmod 400 '.$conf["dist_pureftpd_config_dir"].'/'.$configfile.'~');
      $content = rf("tpl/pureftpd_".$configfile.".master");
      $content = str_replace('{mysql_server_ispconfig_user}',$conf["mysql_server_ispconfig_user"],$content);
      $content = str_replace('{mysql_server_ispconfig_password}',$conf["mysql_server_ispconfig_password"],$content);
      $content = str_replace('{mysql_server_database}',$conf["mysql_server_database"],$content);
      $content = str_replace('{mysql_server_ip}',$conf["mysql_server_ip"],$content);
      $content = str_replace('{server_id}',$conf["server_id"],$content);
      wf($conf["dist_pureftpd_config_dir"].'/'.$configfile,$content);
      exec('chmod 600 '.$conf["dist_pureftpd_config_dir"].'/'.$configfile);
      exec('chown root:root '.$conf["dist_pureftpd_config_dir"].'/'.$configfile);
      // enable chrooting
      exec('echo "yes" > /etc/pure-ftpd/conf/ChrootEveryone');
   }
   function configure_mydns() {
      global $conf;
      // configure pam for SMTP authentication agains the ispconfig database
      $configfile = 'mydns.conf';
      if(is_file($conf["dist_mydns_config_dir"].'/'.$configfile)) copy($conf["dist_mydns_config_dir"].'/'.$configfile,$conf["dist_mydns_config_dir"].'/'.$configfile.'~');
      if(is_file($conf["dist_mydns_config_dir"].'/'.$configfile.'~')) exec('chmod 400 '.$conf["dist_mydns_config_dir"].'/'.$configfile.'~');
      $content = rf("tpl/".$configfile.".master");
      $content = str_replace('{mysql_server_ispconfig_user}',$conf["mysql_server_ispconfig_user"],$content);
      $content = str_replace('{mysql_server_ispconfig_password}',$conf["mysql_server_ispconfig_password"],$content);
      $content = str_replace('{mysql_server_database}',$conf["mysql_server_database"],$content);
      $content = str_replace('{mysql_server_ip}',$conf["mysql_server_ip"],$content);
      $content = str_replace('{server_id}',$conf["server_id"],$content);
      wf($conf["dist_mydns_config_dir"].'/'.$configfile,$content);
      exec('chmod 600 '.$conf["dist_mydns_config_dir"].'/'.$configfile);
      exec('chown root:root '.$conf["dist_mydns_config_dir"].'/'.$configfile);
   }
   
   function install_ispconfig() {
      global $conf;
@@ -466,7 +569,7 @@
      $command = "ln -s ".$conf["ispconfig_install_dir"]."/interface/web/ /var/www/ispconfig";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
      
      // Create the config file for ISPConfig
      // Create the config file for ISPConfig interface
      $configfile = 'config.inc.php';
      if(is_file($conf["ispconfig_install_dir"].'/interface/lib/'.$configfile)) copy($conf["ispconfig_install_dir"].'/interface/lib/'.$configfile,$conf["ispconfig_install_dir"].'/interface/lib/'.$configfile.'~');
      $content = rf("tpl/".$configfile.".master");
@@ -475,6 +578,18 @@
      $content = str_replace('{mysql_server_database}',$conf["mysql_server_database"],$content);
      $content = str_replace('{mysql_server_host}',$conf["mysql_server_host"],$content);
      wf($conf["ispconfig_install_dir"].'/interface/lib/'.$configfile,$content);
      // Create the config file for ISPConfig server
      $configfile = 'config.inc.php';
      if(is_file($conf["ispconfig_install_dir"].'/server/lib/'.$configfile)) copy($conf["ispconfig_install_dir"].'/server/lib/'.$configfile,$conf["ispconfig_install_dir"].'/interface/lib/'.$configfile.'~');
      $content = rf("tpl/".$configfile.".master");
      $content = str_replace('{mysql_server_ispconfig_user}',$conf["mysql_server_ispconfig_user"],$content);
      $content = str_replace('{mysql_server_ispconfig_password}',$conf["mysql_server_ispconfig_password"],$content);
      $content = str_replace('{mysql_server_database}',$conf["mysql_server_database"],$content);
      $content = str_replace('{mysql_server_host}',$conf["mysql_server_host"],$content);
      $content = str_replace('{server_id}',$conf["server_id"],$content);
      wf($conf["ispconfig_install_dir"].'/server/lib/'.$configfile,$content);
      
      // Chmod the files
      $command = "chmod -R 750 ".$conf["ispconfig_install_dir"];
@@ -491,6 +606,49 @@
      $command = "adduser www-data ispconfig";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
      
      // Make the shell scripts executable
      $command = "chmod +x ".$conf["ispconfig_install_dir"]."/server/scripts/*.sh";
      caselog($command." &> /dev/null", __FILE__, __LINE__,"EXECUTED: ".$command,"Failed to execute the command ".$command);
      // Copy the ISPConfig vhost for the controlpanel
      copy('tpl/apache_ispconfig.vhost.master',$conf["dist_apache_vhost_conf_dir"].'/ispconfig.vhost');
      // and create the symlink
      if(!is_link($conf["dist_apache_vhost_conf_enabled_dir"].'/ispconfig.vhost')) {
         exec('ln -s '.$conf["dist_apache_vhost_conf_dir"].'/ispconfig.vhost '.$conf["dist_apache_vhost_conf_enabled_dir"].'/ispconfig.vhost');
      }
   }
   function install_crontab() {
      global $conf;
      // Root Crontab
      exec("crontab -u root -l > crontab.txt");
      $existing_root_cron_jobs = file('crontab.txt');
      $root_cron_jobs = array('* * * * * /usr/bin/php -q /usr/local/ispconfig/server/server.php &> /dev/null');
      foreach($root_cron_jobs as $cron_job) {
         if(!in_array($cron_job."\n",$existing_root_cron_jobs)) {
            $existing_root_cron_jobs[] = $cron_job."\n";
         }
      }
      file_put_contents('crontab.txt',$existing_root_cron_jobs);
      exec("crontab -u root crontab.txt &> /dev/null");
      unlink('crontab.txt');
      // Getmail crontab
      exec("crontab -u getmail -l > crontab.txt");
      $existing_cron_jobs = file('crontab.txt');
      $cron_jobs = array('*/5 * * * * '.$conf["dist_getmail_program"].' -g '.$conf["dist_getmail_config_dir"].' -r '.$conf["dist_getmail_config_dir"].'/*.conf &> /dev/null');
      foreach($cron_jobs as $cron_job) {
         if(!in_array($cron_job."\n",$existing_cron_jobs)) {
            $existing_cron_jobs[] = $cron_job."\n";
         }
      }
      file_put_contents('crontab.txt',$existing_cron_jobs);
      exec("crontab -u getmail crontab.txt &> /dev/null");
      unlink('crontab.txt');
      
   }