install.inc 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. #!/bin/bash
  2. hestia_module_apache_install() {
  3. source $HESTIA/bin/module/func.inc
  4. if hestia_module_isinstalled 'apache' && [ ! "$param_force" ]; then
  5. echo "Apache module is already installed. See 'hestia module info apache'."
  6. return 1
  7. fi
  8. echo "Installing Apache module..."
  9. osal_service_stop $OSAL_SERVICE_APACHE > /dev/null 2>&1
  10. hestia_config_backup 'apache-install' $OSAL_PATH_APACHE_CONF $OSAL_PATH_APACHE_CONF_D
  11. osal_package_preinstall
  12. osal_package_install $OSAL_PKG_APACHE $OSAL_PKG_APACHE_EXTRA
  13. mkdir -p $OSAL_PATH_APACHE_CONF_D/domains
  14. # Enable/disable required modules
  15. osal_apache_module_enable rewrite > /dev/null 2>&1
  16. osal_apache_module_enable suexec > /dev/null 2>&1
  17. osal_apache_module_enable ssl > /dev/null 2>&1
  18. osal_apache_module_enable actions > /dev/null 2>&1
  19. osal_apache_module_disable status > /dev/null 2>&1
  20. cp -f $HESTIA_INSTALL_DIR/$OSAL_PKG_APACHE/${OSAL_PKG_APACHE}.conf $OSAL_PATH_APACHE_CONF/
  21. cp -f $HESTIA_INSTALL_DIR/logrotate/${OSAL_PKG_APACHE} $OSAL_PATH_LOGROTATE_CONF_D/
  22. echo "# Powered by Hestia" > $OSAL_PATH_APACHE_CONF/ports.conf
  23. if [ "$OS_BASE" = 'debian' ]; then
  24. echo "# Powered by Hestia" > $OSAL_PATH_APACHE_CONF/sites-available/default
  25. echo "# Powered by Hestia" > $OSAL_PATH_APACHE_CONF/sites-available/default-ssl
  26. echo -e "/home\npublic_html/cgi-bin" > /etc/apache2/suexec/www-data
  27. hestia_safe_rm $OSAL_PATH_APACHE_CONF/mods-available/hestia-status.load
  28. hestia_safe_rm $OSAL_PATH_APACHE_CONF/mods-available/hestia-status.conf
  29. # Copy configuration files
  30. cp -f $HESTIA_INSTALL_DIR/$OSAL_PKG_APACHE/status.conf $OSAL_PATH_APACHE_MODS_AVAILABLE/
  31. cp -f /etc/apache2/mods-available/status.load $OSAL_PATH_APACHE_MODS_AVAILABLE/
  32. # Prevent remote access to server-status page
  33. sed -i '/Allow from all/d' $OSAL_PATH_APACHE_MODS_AVAILABLE/status.conf
  34. osal_apache_module_enable status > /dev/null 2>&1
  35. elif [ "$OS_BASE" = 'rhel' ]; then
  36. echo "# Powered by Hestia" > $OSAL_PATH_APACHE_CONF_D/ssl.conf
  37. echo "# Powered by Hestia" > $OSAL_PATH_APACHE_CONF_D/welcome.conf
  38. echo "# Powered by Hestia" > $OSAL_PATH_APACHE_CONF_D/userdir.conf
  39. # Copy configuration files
  40. cp -f $HESTIA_INSTALL_DIR/$OSAL_PKG_APACHE/status.conf $OSAL_PATH_APACHE_CONF_D/
  41. # Prevent remote access to server-status page
  42. sed -i '/Allow from all/d' $OSAL_PATH_APACHE_CONF_D/status.conf
  43. osal_apache_module_enable status > /dev/null 2>&1
  44. # Delete CentOS style apache logs if present (Hestia will use error.log and access.log)
  45. [ -f /var/log/$OSAL_PKG_APACHE/access_log ] && hestia_safe_rm /var/log/$OSAL_PKG_APACHE/access_log
  46. [ -f /var/log/$OSAL_PKG_APACHE/error_log ] && hestia_safe_rm /var/log/$OSAL_PKG_APACHE/error_log
  47. # Mitigation for some Debian-only scripts
  48. [ ! -e /etc/httpd/mods-enabled ] && ln -s /etc/httpd/conf.modules.d/ /etc/httpd/mods-enabled
  49. fi
  50. touch /var/log/$OSAL_PKG_APACHE/access.log /var/log/$OSAL_PKG_APACHE/error.log
  51. mkdir -p /var/log/$OSAL_PKG_APACHE/domains
  52. chmod a+x /var/log/$OSAL_PKG_APACHE
  53. chmod 640 /var/log/$OSAL_PKG_APACHE/access.log /var/log/$OSAL_PKG_APACHE/error.log
  54. chmod 751 /var/log/$OSAL_PKG_APACHE/domains
  55. osal_kv_write $HESTIA_CONF_MODULES/apache.conf 'service_name' $OSAL_SERVICE_APACHE
  56. }