| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- #!/bin/bash
- # info: add mail domain
- # options: USER DOMAIN [ANTISPAM] [ANTIVIRUS] [DKIM] [DKIM_SIZE]
- #
- # The function adds MAIL domain.
- #----------------------------------------------------------#
- # Variable&Function #
- #----------------------------------------------------------#
- # Argument definition
- user=$1
- domain=$2
- antispam=${3-yes}
- antivirus=${4-yes}
- dkim=${5-yes}
- dkim_size=${6-1024}
- # Includes
- source $VESTA/func/main.sh
- source $VESTA/func/domain.sh
- source $VESTA/conf/vesta.conf
- # Define mail user
- if [ "$MAIL_SYSTEM" = 'exim4' ]; then
- MAIL_USER=Debian-exim
- else
- MAIL_USER=exim
- fi
- # Additional argument formatting
- format_domain
- format_domain_idn
- #----------------------------------------------------------#
- # Verifications #
- #----------------------------------------------------------#
- check_args '2' "$#" 'USER DOMAIN [ANTISPAM] [ANTIVIRUS] [DKIM] [DKIM_SIZE]'
- is_format_valid 'user' 'domain' 'antispam' 'antivirus' 'dkim' 'dkim_size'
- is_system_enabled "$MAIL_SYSTEM" 'MAIL_SYSTEM'
- is_object_valid 'user' 'USER' "$user"
- is_object_unsuspended 'user' 'USER' "$user"
- is_domain_new 'mail' "$domain"
- is_package_full 'MAIL_DOMAINS'
- #----------------------------------------------------------#
- # Action #
- #----------------------------------------------------------#
- # Generating timestamp
- time_n_date=$(date +'%T %F')
- time=$(echo "$time_n_date" |cut -f 1 -d \ )
- date=$(echo "$time_n_date" |cut -f 2 -d \ )
- # Adding domain to mail.conf
- s="DOMAIN='$domain' ANTIVIRUS='$antivirus' ANTISPAM='$antispam' DKIM='$dkim'"
- s="$s CATCHALL='' ACCOUNTS='0' U_DISK='0' SUSPENDED='no' TIME='$time'"
- s="$s DATE='$date'"
- echo $s >> $USER_DATA/mail.conf
- touch $USER_DATA/mail/$domain.conf
- # Generating DKIM keys
- if [ "$dkim" = 'yes' ]; then
- openssl genrsa -out $USER_DATA/mail/$domain.pem $dkim_size &>/dev/null
- openssl rsa -pubout -in $USER_DATA/mail/$domain.pem \
- -out $USER_DATA/mail/$domain.pub &>/dev/null
- fi
- # Set permissions
- chmod 660 $USER_DATA/mail/$domain.*
- chmod 660 $USER_DATA/mail.conf
- # Building exim configs
- if [[ "$MAIL_SYSTEM" =~ exim ]]; then
- mkdir $HOMEDIR/$user/conf/mail/$domain
- mkdir $HOMEDIR/$user/mail/$domain_idn
- touch $HOMEDIR/$user/conf/mail/$domain/aliases
- touch $HOMEDIR/$user/conf/mail/$domain/passwd
- touch $HOMEDIR/$user/conf/mail/$domain/fwd_only
- ln -s $HOMEDIR/$user/conf/mail/$domain \
- /etc/$MAIL_SYSTEM/domains/$domain_idn
- # Adding antispam protection
- if [ "$antispam" = 'yes' ]; then
- touch $HOMEDIR/$user/conf/mail/$domain/antispam
- fi
- # Adding antivirus protection
- if [ "$antivirus" = 'yes' ]; then
- touch $HOMEDIR/$user/conf/mail/$domain/antivirus
- fi
- # Adding dkim support
- if [ "$dkim" = 'yes' ]; then
- cp -f $USER_DATA/mail/$domain.pem \
- $HOMEDIR/$user/conf/mail/$domain/dkim.pem
- fi
- # Set permission
- chmod 771 $HOMEDIR/$user/conf/mail/$domain
- chmod 660 $HOMEDIR/$user/conf/mail/$domain/*
- chmod 771 /etc/$MAIL_SYSTEM/domains/$domain_idn
- chmod 770 $HOMEDIR/$user/mail/$domain_idn
- # Set ownership
- chown -R $MAIL_USER:mail $HOMEDIR/$user/conf/mail/$domain
- chown -R dovecot:mail $HOMEDIR/$user/conf/mail/$domain/passwd
- chown $user:mail $HOMEDIR/$user/mail/$domain_idn
- fi
- # Adding dkim dns records
- if [ ! -z "$DNS_SYSTEM" ] && [ "$dkim" = 'yes' ]; then
- check_dns_domain=$(is_object_valid 'dns' 'DOMAIN' "$domain")
- if [ "$?" -eq 0 ]; then
- p=$(cat $USER_DATA/mail/$domain.pub|grep -v ' KEY---'|tr -d '\n')
- record='_domainkey'
- policy="\"t=y; o=~;\""
- $BIN/v-add-dns-record $user $domain $record TXT "$policy" '' '' 'no'
- record='mail._domainkey'
- selector="\"v=DKIM1\; k=rsa\; p=$p\""
- $BIN/v-add-dns-record $user $domain $record TXT "$selector"
- fi
- fi
- #----------------------------------------------------------#
- # Vesta #
- #----------------------------------------------------------#
- # Increasing domain value
- increase_user_value "$user" '$U_MAIL_DOMAINS'
- if [ "$dkim" = 'yes' ]; then
- increase_user_value "$user" '$U_MAIL_DKMI'
- fi
- # Logging
- log_history "added mail domain $domain"
- log_event "$OK" "$ARGUMENTS"
- exit
|