install.inc 3.7 KB

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