| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- #!/bin/bash
- # info: add mail domain dkim support
- # options: user domain [dkim_size]
- #
- # The function adds DKIM signature to outgoing domain emails.
- #----------------------------------------------------------#
- # Variable&Function #
- #----------------------------------------------------------#
- # Argument defenition
- user=$1
- domain=$(idn -t --quiet -u "$2" )
- domain=$(echo $domain | tr '[:upper:]' '[:lower:]')
- domain_idn=$(idn -t --quiet -a "$domain")
- dkim_size=${3-512}
- # Includes
- source $VESTA/conf/vesta.conf
- source $VESTA/func/main.sh
- source $VESTA/func/domain.sh
- #----------------------------------------------------------#
- # Verifications #
- #----------------------------------------------------------#
- check_args '2' "$#" 'user domain [dkim_size]'
- validate_format 'user' 'domain' 'dkim_size'
- is_system_enabled "$MAIL_SYSTEM"
- is_object_valid 'user' 'USER' "$user"
- is_object_unsuspended 'user' 'USER' "$user"
- is_object_valid 'mail' 'DOMAIN' "$domain"
- is_object_unsuspended 'mail' 'DOMAIN' "$domain"
- is_object_value_empty 'mail' 'DOMAIN' "$domain" '$DKIM'
- #----------------------------------------------------------#
- # Action #
- #----------------------------------------------------------#
- # Generating dkim
- 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
- chmod 660 $USER_DATA/mail/$domain.*
- # Adding dkim to config
- cp $USER_DATA/mail/$domain.pem $HOMEDIR/$user/conf/mail/$domain/dkim.pem
- chown root:mail $HOMEDIR/$user/conf/mail/$domain/dkim.pem
- chmod 660 $HOMEDIR/$user/conf/mail/$domain/dkim.pem
- # Checking dns domain
- check_dns_domain=$(is_object_valid 'dns' 'DOMAIN' "$domain")
- if [ "$?" -eq 0 ]; then
- # Adding dkim dns records
- p=$(cat $USER_DATA/mail/$domain.pub|grep -v ' KEY---'|tr -d '\n')
- record='_domainkey'
- policy="\"t=y; o=~;\""
- $BIN/v_add_dns_domain_record $user $domain $record TXT "$policy"
- record='mail._domainkey'
- selector="\"k=rsa\; p=$p\""
- $BIN/v_add_dns_domain_record $user $domain $record TXT "$selector"
- fi
- #----------------------------------------------------------#
- # Vesta #
- #----------------------------------------------------------#
- # Adding dkim in config
- update_object_value 'mail' 'DOMAIN' "$domain" '$DKIM' 'yes'
- increase_user_value "$user" '$U_MAIL_DKMI'
- # Logging
- log_history "$EVENT"
- log_event "$OK" "$EVENT"
- exit
|