mirror of
https://github.com/serghey-rodin/vesta.git
synced 2025-01-23 11:13:01 -08:00
132 lines
3.3 KiB
Bash
Executable File
132 lines
3.3 KiB
Bash
Executable File
#!/bin/bash
|
|
# info: adding ssl for domain
|
|
|
|
#----------------------------------------------------------#
|
|
# Variable&Function #
|
|
#----------------------------------------------------------#
|
|
|
|
# Argument defenition
|
|
user="$1"
|
|
domain=$(idn -t --quiet -u "$2" )
|
|
domain_idn=$(idn -t --quiet -a "$domain")
|
|
cert="$3"
|
|
tpl_option="${4-single}"
|
|
|
|
# Importing variables
|
|
source $VESTA/conf/vars.conf
|
|
source $V_FUNC/shared_func.sh
|
|
source $V_FUNC/domain_func.sh
|
|
source $V_FUNC/ip_func.sh
|
|
|
|
|
|
#----------------------------------------------------------#
|
|
# Verifications #
|
|
#----------------------------------------------------------#
|
|
|
|
# Checking arg number
|
|
check_args '3' "$#" 'user domain certificate [sslhome]'
|
|
|
|
# Checking argument format
|
|
format_validation 'user' 'domain' 'certificate'
|
|
|
|
# Checking web system is enabled
|
|
is_system_enabled 'web'
|
|
|
|
# Checking user
|
|
is_user_valid
|
|
|
|
# Checking user is active
|
|
is_user_suspended
|
|
|
|
# Checking domain exist
|
|
is_web_domain_valid
|
|
|
|
# Checking domain is not suspened
|
|
is_domain_suspended 'web_domains'
|
|
|
|
# Checking package
|
|
is_package_full 'web_ssl'
|
|
|
|
# Checking ip ownership
|
|
ip=$(get_web_domain_value '$IP')
|
|
is_sys_ip_owner
|
|
|
|
# Check ssl is not added
|
|
is_web_domain_key_empty '$SSL_CERT'
|
|
|
|
# Checking ssl certificate
|
|
is_web_domain_cert_valid
|
|
|
|
# Checking template
|
|
templates=$(get_user_value '$WEB_TPL')
|
|
template=$(get_web_domain_value '$TPL')
|
|
is_template_valid 'web'
|
|
|
|
|
|
#----------------------------------------------------------#
|
|
# Action #
|
|
#----------------------------------------------------------#
|
|
|
|
# Defining variables for template replace
|
|
web_ssl_port=$(get_config_value '$WEB_SSL_PORT')
|
|
aliases=$(get_web_domain_value '$ALIAS')
|
|
aliases_idn=$(idn -t --quiet -a "$aliases")
|
|
email="$user@$domain"
|
|
ssl_cert="$V_HOME/$user/conf/$cert.crt"
|
|
ssl_key="$V_HOME/$user/conf/$cert.key"
|
|
case $tpl_option in
|
|
single) docroot="$V_HOME/$user/domains/$domain/public_shtml" ;;
|
|
same) docroot="$V_HOME/$user/domains/$domain/public_html" ;;
|
|
*) check_args '3' "$#" 'user domain certificate [sslhome]'
|
|
esac
|
|
group="$user"
|
|
conf="$V_HOME/$user/conf/shttpd.conf"
|
|
tpl_file="$V_WEBTPL/apache_$template.stpl"
|
|
|
|
# Checking error log status
|
|
elog=$(get_web_domain_value '$ELOG')
|
|
if [ "$elog" = 'no' ]; then
|
|
elog=' #'
|
|
else
|
|
elog=' '
|
|
fi
|
|
|
|
# Adding domain to the httpd.conf
|
|
add_web_config
|
|
|
|
# Adding certificate to user dir
|
|
if [ ! -e "$ssl_cert" ]; then
|
|
cp -f $V_USERS/$user/cert/$cert.crt $ssl_cert
|
|
cp -f $V_USERS/$user/cert/$cert.key $ssl_key
|
|
fi
|
|
|
|
# Running template trigger
|
|
if [ -x $V_WEBTPL/apache_$template.sh ]; then
|
|
$V_WEBTPL/apache_$template.sh $user $domain $ip $V_HOME $docroot
|
|
fi
|
|
|
|
# Checking main vesta httpd config
|
|
main_conf='/etc/httpd/conf.d/vesta.conf'
|
|
main_conf_check=$(grep "$conf" $main_conf )
|
|
if [ -z "$main_conf_check" ]; then
|
|
echo "Include $conf" >>$main_conf
|
|
fi
|
|
|
|
|
|
#----------------------------------------------------------#
|
|
# Vesta #
|
|
#----------------------------------------------------------#
|
|
|
|
# Increasing domain value
|
|
increase_user_value "$user" '$U_WEB_SSL'
|
|
|
|
# Adding ssl values
|
|
update_web_domain_value '$SSL_HOME' "$tpl_option"
|
|
update_web_domain_value '$SSL_CERT' "$cert"
|
|
|
|
# Logging
|
|
log_history "$V_EVENT" "v_del_web_domain_ssl $user $domain"
|
|
log_event 'system' "$V_EVENT"
|
|
|
|
exit $OK
|