| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- #!/bin/bash
- # info: add dns record
- # options: USER DOMAIN RECORD TYPE VALUE [PRIORITY] [ID] [RESTART]
- #
- # The call is used for adding new DNS record. Complex records of TXT, MX and
- # SRV types can be used by a filling in the 'value' argument. The function also
- # gets an id parameter for definition of certain record identifier or for the
- # regulation of records.
- #----------------------------------------------------------#
- # 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")
- record=$(idn -t --quiet -u "$3" )
- record=$(echo "$record" | tr '[:upper:]' '[:lower:]')
- rtype=$(echo "$4"| tr '[:lower:]' '[:upper:]')
- dvalue=$(idn -t --quiet -u "$5" )
- priority=$6
- id=$7
- restart=$8
- if [ -z "$priority" ]; then
- priority=10
- fi
- # Includes
- source $VESTA/func/main.sh
- source $VESTA/func/domain.sh
- source $VESTA/conf/vesta.conf
- # Null priority for none MX/SRV records
- if [ "$rtype" != 'MX' ] && [ "$rtype" != 'SRV' ]; then
- priority=''
- fi
- # Add trailing dot at the end of NS/CNAME/MX/PTR/SRV record
- fqdn_type=$(echo $rtype |grep "NS\|CNAME\|MX\|PTR\|SRV")
- if [ ! -z "$fqdn_type" ]; then
- trailing_dot=$(echo $dvalue | grep "\.$")
- if [ -z $trailing_dot ]; then
- dvalue="$dvalue."
- fi
- fi
- #----------------------------------------------------------#
- # Verifications #
- #----------------------------------------------------------#
- check_args '5' "$#" 'USER DOMAIN RECORD TYPE VALUE [PRIORITY] [ID] [RESTART]'
- validate_format 'user' 'domain' 'record' 'rtype' 'dvalue'
- is_system_enabled "$DNS_SYSTEM" 'DNS_SYSTEM'
- is_object_valid 'user' 'USER' "$user"
- is_object_unsuspended 'user' 'USER' "$user"
- is_object_valid 'dns' 'DOMAIN' "$domain"
- is_object_unsuspended 'dns' 'DOMAIN' "$domain"
- is_package_full 'DNS_RECORDS'
- get_next_dnsrecord
- validate_format 'id'
- is_object_new "dns/$domain" 'ID' "$id"
- is_dns_fqnd "$rtype" "$dvalue"
- is_dns_nameserver_valid "$domain" "$rtype" "$dvalue"
- #----------------------------------------------------------#
- # Action #
- #----------------------------------------------------------#
- # Adding record
- zone="$USER_DATA/dns/$domain.conf"
- dns_rec="ID='$id' RECORD='$record' TYPE='$rtype' PRIORITY='$priority'"
- dns_rec="$dns_rec VALUE='$dvalue' SUSPENDED='no' TIME='$TIME' DATE='$DATE'"
- echo "$dns_rec" >> $zone
- chmod 660 $zone
- # Sorting records
- sort_dns_records
- # Updating zone
- update_domain_zone
- # dns-cluster
- if [ ! -z "$DNS_CLUSTER" ]; then
- # Check for first sync
- dlock=$(grep "domain $user $domain" $VESTA/data/queue/dns-cluster.pipe)
- if [ -z "$dlock" ]; then
- cmd="$BIN/v-add-remote-dns-record $user $domain $id"
- echo "$cmd" >> $VESTA/data/queue/dns-cluster.pipe
- fi
- fi
- #----------------------------------------------------------#
- # Vesta #
- #----------------------------------------------------------#
- # Upddate counters
- records="$(wc -l $USER_DATA/dns/$domain.conf | cut -f1 -d ' ')"
- update_object_value 'dns' 'DOMAIN' "$domain" '$RECORDS' "$records"
- increase_user_value "$user" '$U_DNS_RECORDS'
- # Restart named
- if [ "$restart" != 'no' ]; then
- $BIN/v-restart-dns
- if [ $? -ne 0 ]; then
- exit E_RESTART
- fi
- fi
- # Logging
- log_history "added $rtype dns record $record for $domain"
- log_event "$OK" "$EVENT"
- exit
|