install.inc 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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 $OSAL_PKG_APACHE_MOD_RUID2
  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. # Copy configuration files
  28. # FIXME: why don't we just overwrite status.conf? That will be more portable
  29. a2dismod status > /dev/null 2>&1
  30. mv -f $HESTIA_INSTALL_DIR/$OSAL_PKG_APACHE/status.conf $OSAL_PATH_APACHE_CONF/mods-available/hestia-status.conf
  31. mv -f /etc/apache2/mods-available/status.load $OSAL_PATH_APACHE_CONF/mods-available/hestia-status.load
  32. a2enmod hestia-status > /dev/null 2>&1
  33. # Prevent remote access to server-status page
  34. sed -i '/Allow from all/d' $OSAL_PATH_APACHE_CONF/mods-available/hestia-status.conf
  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/hestia-status.conf
  41. osal_apache_module_enable status > /dev/null 2>&1
  42. # Delete CentOS style apache logs if present (Hestia will use error.log and access.log)
  43. [ -f /var/log/$OSAL_PKG_APACHE/access_log ] && hestia_safe_rm /var/log/$OSAL_PKG_APACHE/access_log
  44. [ -f /var/log/$OSAL_PKG_APACHE/error_log ] && hestia_safe_rm /var/log/$OSAL_PKG_APACHE/error_log
  45. # Mitigation for some Debian-only scripts
  46. ln -s /etc/httpd/conf.modules.d/ /etc/httpd/mods-enabled
  47. fi
  48. touch /var/log/$OSAL_PKG_APACHE/access.log /var/log/$OSAL_PKG_APACHE/error.log
  49. mkdir -p /var/log/$OSAL_PKG_APACHE/domains
  50. chmod a+x /var/log/$OSAL_PKG_APACHE
  51. chmod 640 /var/log/$OSAL_PKG_APACHE/access.log /var/log/$OSAL_PKG_APACHE/error.log
  52. chmod 751 /var/log/$OSAL_PKG_APACHE/domains
  53. osal_kv_write $HESTIA_CONF_MODULES/apache.conf 'installed' '1'
  54. osal_kv_write $HESTIA_CONF_MODULES/apache.conf 'description' 'Hestia Apache module'
  55. osal_kv_write $HESTIA_CONF_MODULES/apache.conf 'enabled' '1'
  56. osal_kv_write $HESTIA_CONF_MODULES/apache.conf 'variant' 'apache'
  57. osal_kv_write $HESTIA_CONF_MODULES/apache.conf 'version' '1'
  58. osal_kv_write $HESTIA_CONF_MODULES/apache.conf 'service_name' $OSAL_PKG_APACHE
  59. # Setup web module (depending on Nginx and/or Apache config)
  60. $BIN/hestia module web setup
  61. }