v-add-mail-domain 4.3 KB

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