v-add-mail-domain 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  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 defenition
  10. user=$1
  11. domain=$(idn -t --quiet -u "$2" )
  12. domain=$(echo $domain | sed -e 's/\.*$//g' -e 's/^\.*//g')
  13. domain=$(echo $domain | tr '[:upper:]' '[:lower:]')
  14. domain_idn=$(idn -t --quiet -a "$domain")
  15. antispam=${3-yes}
  16. antivirus=${4-yes}
  17. dkim=${5-yes}
  18. dkim_size=${6-1024}
  19. # Includes
  20. source $VESTA/func/main.sh
  21. source $VESTA/func/domain.sh
  22. source $VESTA/conf/vesta.conf
  23. #----------------------------------------------------------#
  24. # Verifications #
  25. #----------------------------------------------------------#
  26. check_args '2' "$#" 'USER DOMAIN [ANTISPAM] [ANTIVIRUS] [DKIM] [DKIM_SIZE]'
  27. validate_format 'user' 'domain' 'antispam' 'antivirus' 'dkim' 'dkim_size'
  28. is_system_enabled "$MAIL_SYSTEM" 'MAIL_SYSTEM'
  29. is_object_valid 'user' 'USER' "$user"
  30. is_object_unsuspended 'user' 'USER' "$user"
  31. is_domain_new 'mail'
  32. is_package_full 'MAIL_DOMAINS'
  33. #----------------------------------------------------------#
  34. # Action #
  35. #----------------------------------------------------------#
  36. # Adding domain directory and necessary files
  37. mkdir $HOMEDIR/$user/conf/mail/$domain
  38. mkdir $HOMEDIR/$user/mail/$domain_idn
  39. touch $HOMEDIR/$user/conf/mail/$domain/aliases
  40. touch $HOMEDIR/$user/conf/mail/$domain/passwd
  41. # Adding symlink
  42. ln -s $HOMEDIR/$user/conf/mail/$domain /etc/$MAIL_SYSTEM/domains/$domain_idn
  43. # Adding antispam protection
  44. if [ "$antispam" = 'yes' ]; then
  45. touch $HOMEDIR/$user/conf/mail/$domain/antispam
  46. fi
  47. # Adding antivirus protection
  48. if [ "$antivirus" = 'yes' ]; then
  49. touch $HOMEDIR/$user/conf/mail/$domain/antivirus
  50. fi
  51. # Adding dkim
  52. if [ "$dkim" = 'yes' ]; then
  53. openssl genrsa -out $USER_DATA/mail/$domain.pem $dkim_size &>/dev/null
  54. openssl rsa -pubout -in $USER_DATA/mail/$domain.pem \
  55. -out $USER_DATA/mail/$domain.pub &>/dev/null
  56. chmod 660 $USER_DATA/mail/$domain.*
  57. cp $USER_DATA/mail/$domain.pem $HOMEDIR/$user/conf/mail/$domain/dkim.pem
  58. # Adding dkim dns records
  59. check_dns_domain=$(is_object_valid 'dns' 'DOMAIN' "$domain")
  60. if [ "$?" -eq 0 ]; then
  61. p=$(cat $USER_DATA/mail/$domain.pub|grep -v ' KEY---'|tr -d '\n')
  62. record='_domainkey'
  63. policy="\"t=y; o=~;\""
  64. $BIN/v-add-dns-record $user $domain $record TXT "$policy"
  65. record='mail._domainkey'
  66. selector="\"k=rsa\; p=$p\""
  67. $BIN/v-add-dns-record $user $domain $record TXT "$selector"
  68. fi
  69. fi
  70. # Adding domain to vesta db
  71. s="DOMAIN='$domain' ANTIVIRUS='$antivirus' ANTISPAM='$antispam' DKIM='$dkim'"
  72. s="$s ACCOUNTS='0' U_DISK='0' CATCHALL='' SUSPENDED='no' TIME='$TIME'"
  73. s="$s DATE='$DATE'"
  74. # Set permissions
  75. chmod 660 $USER_DATA/mail/$domain.*
  76. chmod 771 $HOMEDIR/$user/conf/mail/$domain
  77. chmod 660 $HOMEDIR/$user/conf/mail/$domain/*
  78. chmod 771 /etc/$MAIL_SYSTEM/domains/$domain_idn
  79. chmod 770 $HOMEDIR/$user/mail/$domain_idn
  80. # Set ownership
  81. if [ "$MAIL_SYSTEM" = 'exim' ]; then
  82. mail_user=exim
  83. fi
  84. if [ "$MAIL_SYSTEM" = 'exim4' ]; then
  85. mail_user=Debian-exim
  86. fi
  87. chown -R $mail_user:mail $HOMEDIR/$user/conf/mail/$domain
  88. chown -R dovecot:mail $HOMEDIR/$user/conf/mail/$domain/passwd
  89. chown $user:mail $HOMEDIR/$user/mail/$domain_idn
  90. echo $s >> $USER_DATA/mail.conf
  91. touch $USER_DATA/mail/$domain.conf
  92. chmod 660 $USER_DATA/mail.conf
  93. chmod 660 $USER_DATA/mail/$domain.conf
  94. #----------------------------------------------------------#
  95. # Vesta #
  96. #----------------------------------------------------------#
  97. # Increasing domain value
  98. increase_user_value "$user" '$U_MAIL_DOMAINS'
  99. if [ "$dkim" = 'yes' ]; then
  100. increase_user_value "$user" '$U_MAIL_DKMI'
  101. fi
  102. # Logging
  103. log_history "added mail domain $domain"
  104. log_event "$OK" "$EVENT"
  105. exit