mirror of
https://github.com/myvesta/vesta.git
synced 2024-11-03 04:00:20 -08:00
80 lines
2.5 KiB
Bash
80 lines
2.5 KiB
Bash
#!/bin/bash
|
|
|
|
# info: Copy host SSL as IP SSL
|
|
# options: USER DOMAIN
|
|
#
|
|
# The function check if specific (sub)domain is marked as main host for specific IP, get its SSL and put it as IP SSL in /usr/local/vesta/ssl/
|
|
|
|
#----------------------------------------------------------#
|
|
# Variable&Function #
|
|
#----------------------------------------------------------#
|
|
|
|
whoami=$(whoami)
|
|
if [ "$whoami" != "root" ]; then
|
|
echo "You must be root to execute this script"
|
|
exit 1
|
|
fi
|
|
|
|
# Argument definition
|
|
user=$1
|
|
domain=$2
|
|
|
|
# Importing system environment
|
|
source /etc/profile
|
|
|
|
# Includes
|
|
source /usr/local/vesta/func/main.sh
|
|
|
|
#----------------------------------------------------------#
|
|
# Verifications #
|
|
#----------------------------------------------------------#
|
|
|
|
check_args '2' "$#" 'USER DOMAIN'
|
|
is_format_valid 'user' 'domain'
|
|
is_object_valid 'user' 'USER' "$user"
|
|
is_object_unsuspended 'user' 'USER' "$user"
|
|
|
|
#----------------------------------------------------------#
|
|
# Action #
|
|
#----------------------------------------------------------#
|
|
|
|
if [ ! -f "/etc/exim4/virtual/helo_data" ]; then
|
|
exit 1
|
|
fi
|
|
|
|
echo "Script ran with: $user $domain" >> /usr/local/vesta/log/v-make-ip-ssl.log
|
|
|
|
grepr=$(grep -c ": $domain$" /etc/exim4/virtual/helo_data)
|
|
if [ $grepr -ge 1 ]; then
|
|
ip=$(grep ": $domain$" /etc/exim4/virtual/helo_data | awk -F: '{print $1}')
|
|
if [ ! -z "$ip" ]; then
|
|
echo "Processinng $domain" >> /usr/local/vesta/log/v-make-ip-ssl.log
|
|
echo "IP = $ip" >> /usr/local/vesta/log/v-make-ip-ssl.log
|
|
cp /home/$user/conf/web/ssl.$domain.pem /usr/local/vesta/ssl/$ip.crt
|
|
cp /home/$user/conf/web/ssl.$domain.key /usr/local/vesta/ssl/$ip.key
|
|
|
|
exim_user="exim";
|
|
check_exim_username=$(grep -c '^Debian-exim:' /etc/passwd)
|
|
if [ "$check_exim_username" -eq 1 ]; then
|
|
exim_user="Debian-exim"
|
|
fi
|
|
|
|
# Assign exim permissions
|
|
chown $exim_user:mail /usr/local/vesta/ssl/$ip.crt
|
|
chown $exim_user:mail /usr/local/vesta/ssl/$ip.key
|
|
|
|
service exim4 restart
|
|
service dovecot restart
|
|
echo "Done." >> /usr/local/vesta/log/v-make-ip-ssl.log
|
|
fi
|
|
fi
|
|
|
|
#----------------------------------------------------------#
|
|
# Vesta #
|
|
#----------------------------------------------------------#
|
|
|
|
# Logging
|
|
log_event "$OK" "$ARGUMENTS"
|
|
|
|
exit
|