You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					107 lines
				
				2.9 KiB
			
		
		
			
		
	
	
					107 lines
				
				2.9 KiB
			| 
											2 years ago
										 | #!/bin/bash | ||
|  | # info: rebuild dns domains | ||
|  | # options: USER [RESTART] [UPDATE_SERIAL] | ||
|  | # | ||
|  | # example: v-rebuild-dns-domains alice | ||
|  | # | ||
|  | # This function rebuilds DNS configuration files. | ||
|  | 
 | ||
|  | #----------------------------------------------------------# | ||
|  | #                Variables & Functions                     # | ||
|  | #----------------------------------------------------------# | ||
|  | 
 | ||
|  | # Argument definition | ||
|  | user=$1 | ||
|  | restart=$2 | ||
|  | update_serial=${3-no} | ||
|  | 
 | ||
|  | # Includes | ||
|  | # shellcheck source=/etc/hestiacp/hestia.conf | ||
|  | source /etc/hestiacp/hestia.conf | ||
|  | # shellcheck source=/usr/local/hestia/func/main.sh | ||
|  | source $HESTIA/func/main.sh | ||
|  | # shellcheck source=/usr/local/hestia/func/domain.sh | ||
|  | source $HESTIA/func/domain.sh | ||
|  | # shellcheck source=/usr/local/hestia/func/rebuild.sh | ||
|  | source $HESTIA/func/rebuild.sh | ||
|  | # shellcheck source=/usr/local/hestia/func/syshealth.sh | ||
|  | source $HESTIA/func/syshealth.sh | ||
|  | # load config file | ||
|  | source_conf "$HESTIA/conf/hestia.conf" | ||
|  | 
 | ||
|  | #----------------------------------------------------------# | ||
|  | #                    Verifications                         # | ||
|  | #----------------------------------------------------------# | ||
|  | 
 | ||
|  | check_args '1' "$#" 'USER [RESTART] [UPDATE_SERIAL]' | ||
|  | is_format_valid 'user' 'restart' | ||
|  | is_system_enabled "$DNS_SYSTEM" 'DNS_SYSTEM' | ||
|  | is_object_valid 'user' 'USER' "$user" | ||
|  | check_user=$(is_object_unsuspended 'user' 'USER' "$user") | ||
|  | if [ -n "$check_user" ]; then | ||
|  | 	exit | ||
|  | fi | ||
|  | if [ "$DNS_SYSTEM" = 'remote' ]; then | ||
|  | 	exit | ||
|  | fi | ||
|  | 
 | ||
|  | # Perform verification if read-only mode is enabled | ||
|  | check_hestia_demo_mode | ||
|  | 
 | ||
|  | #----------------------------------------------------------# | ||
|  | #                       Action                             # | ||
|  | #----------------------------------------------------------# | ||
|  | 
 | ||
|  | user_domains=0 | ||
|  | user_records=0 | ||
|  | suspended_dns=0 | ||
|  | export conf="$USER_DATA/dns.conf" | ||
|  | 
 | ||
|  | # Defining user name servers | ||
|  | ns=$(get_user_value '$NS') | ||
|  | i=1 | ||
|  | for nameserver in ${ns//,/ }; do | ||
|  | 	eval ns$i="$nameserver" | ||
|  | 	i=$((i + 1)) | ||
|  | done | ||
|  | 
 | ||
|  | # Get dns config path | ||
|  | if [ -e '/etc/named.conf' ]; then | ||
|  | 	dns_conf='/etc/named.conf' | ||
|  | fi | ||
|  | 
 | ||
|  | if [ -e '/etc/bind/named.conf' ]; then | ||
|  | 	dns_conf='/etc/bind/named.conf' | ||
|  | fi | ||
|  | 
 | ||
|  | # Remove old user's zone | ||
|  | sed -i "/\/$user\/conf\/dns/d" $dns_conf | ||
|  | 
 | ||
|  | # Starting loop | ||
|  | for domain in $(search_objects 'dns' 'DOMAIN' "*" 'DOMAIN'); do | ||
|  | 	if [ "$update_serial" != 'no' ]; then | ||
|  | 		update_domain_serial | ||
|  | 	fi | ||
|  | 	syshealth_repair_dns_config | ||
|  | 	rebuild_dns_domain_conf | ||
|  | done | ||
|  | 
 | ||
|  | #----------------------------------------------------------# | ||
|  | #                       Hestia                             # | ||
|  | #----------------------------------------------------------# | ||
|  | 
 | ||
|  | # Updating counters | ||
|  | update_user_value "$user" '$U_DNS_DOMAINS' "$user_domains" | ||
|  | update_user_value "$user" '$U_DNS_RECORDS' "$user_records" | ||
|  | update_user_value "$user" '$SUSPENDED_DNS' "$suspended_dns" | ||
|  | 
 | ||
|  | # Restarting named | ||
|  | $BIN/v-restart-dns "$restart" | ||
|  | check_result $? "Bind restart failed" > /dev/null | ||
|  | 
 | ||
|  | # Logging | ||
|  | $BIN/v-log-action "system" "Info" "System" "Rebuilt DNS zones (User: $user)." | ||
|  | log_event "$OK" "$ARGUMENTS" | ||
|  | 
 | ||
|  | exit |