v-add-mail-domain 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. #!/bin/bash
  2. # info: add mail domain
  3. # options: USER DOMAIN [ANTISPAM] [ANTIVIRUS] [DKIM] [DKIM_SIZE]
  4. #
  5. # The function adds MAIL domain.
  6. #----------------------------------------------------------#
  7. # Variable&Function #
  8. #----------------------------------------------------------#
  9. # Argument definition
  10. user=$1
  11. domain=$(idn -t --quiet -u "$2" )
  12. domain=$(echo $domain | sed -e 's/\.*$//g' -e 's/^\.*//g')
  13. if [[ "$domain" =~ [[:upper:]] ]]; then
  14. domain=$(echo "$domain" |tr '[:upper:]' '[:lower:]')
  15. fi
  16. domain_idn="$domain"
  17. if [[ "$domain" = *[![:ascii:]]* ]]; then
  18. domain_idn=$(idn -t --quiet -a $domain)
  19. fi
  20. antispam=${3-yes}
  21. antivirus=${4-yes}
  22. dkim=${5-yes}
  23. dkim_size=${6-1024}
  24. # Includes
  25. source $VESTA/func/main.sh
  26. source $VESTA/func/domain.sh
  27. source $VESTA/conf/vesta.conf
  28. # Define mail user
  29. if [ "$MAIL_SYSTEM" = 'exim4' ]; then
  30. MAIL_USER=Debian-exim
  31. else
  32. MAIL_USER=exim
  33. fi
  34. #----------------------------------------------------------#
  35. # Verifications #
  36. #----------------------------------------------------------#
  37. check_args '2' "$#" 'USER DOMAIN [ANTISPAM] [ANTIVIRUS] [DKIM] [DKIM_SIZE]'
  38. is_format_valid 'user' 'domain' 'antispam' 'antivirus' 'dkim' 'dkim_size'
  39. is_system_enabled "$MAIL_SYSTEM" 'MAIL_SYSTEM'
  40. is_object_valid 'user' 'USER' "$user"
  41. is_object_unsuspended 'user' 'USER' "$user"
  42. is_domain_new 'mail' "$domain"
  43. is_package_full 'MAIL_DOMAINS'
  44. #----------------------------------------------------------#
  45. # Action #
  46. #----------------------------------------------------------#
  47. # Generating timestamp
  48. time_n_date=$(date +'%T %F')
  49. time=$(echo "$time_n_date" |cut -f 1 -d \ )
  50. date=$(echo "$time_n_date" |cut -f 2 -d \ )
  51. # Adding domain to mail.conf
  52. s="DOMAIN='$domain' ANTIVIRUS='$antivirus' ANTISPAM='$antispam' DKIM='$dkim'"
  53. s="$s CATCHALL='' ACCOUNTS='0' U_DISK='0' SUSPENDED='no' TIME='$time'"
  54. s="$s DATE='$date'"
  55. echo $s >> $USER_DATA/mail.conf
  56. touch $USER_DATA/mail/$domain.conf
  57. # Generating DKIM keys
  58. if [ "$dkim" = 'yes' ]; then
  59. openssl genrsa -out $USER_DATA/mail/$domain.pem $dkim_size &>/dev/null
  60. openssl rsa -pubout -in $USER_DATA/mail/$domain.pem \
  61. -out $USER_DATA/mail/$domain.pub &>/dev/null
  62. fi
  63. # Set permissions
  64. chmod 660 $USER_DATA/mail/$domain.*
  65. chmod 660 $USER_DATA/mail.conf
  66. # Building exim configs
  67. if [[ "$MAIL_SYSTEM" =~ exim ]]; then
  68. mkdir $HOMEDIR/$user/conf/mail/$domain
  69. mkdir $HOMEDIR/$user/mail/$domain_idn
  70. touch $HOMEDIR/$user/conf/mail/$domain/aliases
  71. touch $HOMEDIR/$user/conf/mail/$domain/passwd
  72. touch $HOMEDIR/$user/conf/mail/$domain/fwd_only
  73. ln -s $HOMEDIR/$user/conf/mail/$domain \
  74. /etc/$MAIL_SYSTEM/domains/$domain_idn
  75. # Adding antispam protection
  76. if [ "$antispam" = 'yes' ]; then
  77. touch $HOMEDIR/$user/conf/mail/$domain/antispam
  78. fi
  79. # Adding antivirus protection
  80. if [ "$antivirus" = 'yes' ]; then
  81. touch $HOMEDIR/$user/conf/mail/$domain/antivirus
  82. fi
  83. # Adding dkim support
  84. if [ "$dkim" = 'yes' ]; then
  85. cp -f $USER_DATA/mail/$domain.pem \
  86. $HOMEDIR/$user/conf/mail/$domain/dkim.pem
  87. fi
  88. # Set permission
  89. chmod 771 $HOMEDIR/$user/conf/mail/$domain
  90. chmod 660 $HOMEDIR/$user/conf/mail/$domain/*
  91. chmod 771 /etc/$MAIL_SYSTEM/domains/$domain_idn
  92. chmod 770 $HOMEDIR/$user/mail/$domain_idn
  93. # Set ownership
  94. chown -R $MAIL_USER:mail $HOMEDIR/$user/conf/mail/$domain
  95. chown -R dovecot:mail $HOMEDIR/$user/conf/mail/$domain/passwd
  96. chown $user:mail $HOMEDIR/$user/mail/$domain_idn
  97. fi
  98. # Adding dkim dns records
  99. if [ ! -z "$DNS_SYSTEM" ] && [ "$dkim" = 'yes' ]; then
  100. check_dns_domain=$(is_object_valid 'dns' 'DOMAIN' "$domain")
  101. if [ "$?" -eq 0 ]; then
  102. p=$(cat $USER_DATA/mail/$domain.pub|grep -v ' KEY---'|tr -d '\n')
  103. record='_domainkey'
  104. policy="\"t=y; o=~;\""
  105. $BIN/v-add-dns-record $user $domain $record TXT "$policy"
  106. record='mail._domainkey'
  107. selector="\"k=rsa\; p=$p\""
  108. $BIN/v-add-dns-record $user $domain $record TXT "$selector"
  109. fi
  110. fi
  111. #----------------------------------------------------------#
  112. # Vesta #
  113. #----------------------------------------------------------#
  114. # Increasing domain value
  115. increase_user_value "$user" '$U_MAIL_DOMAINS'
  116. if [ "$dkim" = 'yes' ]; then
  117. increase_user_value "$user" '$U_MAIL_DKMI'
  118. fi
  119. # Logging
  120. log_history "added mail domain $domain"
  121. log_event "$OK" "$ARGUMENTS"
  122. exit