X7ROOT File Manager
Current Path:
/usr/local/cpanel/scripts
usr
/
local
/
cpanel
/
scripts
/
📁
..
📄
MirrorSearch_pingtest
(2.38 KB)
📄
activesync-invite-reply
(1.69 KB)
📄
add_dns
(2.36 KB)
📄
adddns
(2.36 KB)
📄
addpop
(6.08 KB)
📄
addsystemuser
(3.27 KB)
📄
adduser
(92 B)
📄
apachelimits
(4.31 KB)
📄
archive_sync_zones
(3.02 KB)
📄
auto-adjust-mysql-limits
(1.81 KB)
📄
autorepair
(1.24 KB)
📄
backups_clean_metadata_for_missing_backups
(1.57 KB)
📄
backups_create_metadata
(15.75 KB)
📄
backups_list_user_files
(4.56 KB)
📄
balance_linked_node_quotas
(2.58 KB)
📄
biglogcheck
(1.69 KB)
📄
build_bandwidthdb_root_cache_in_background
(1.52 KB)
📄
build_cpnat
(3.41 KB)
📄
build_mail_sni
(3.87 KB)
📄
build_maxemails_config
(1.14 KB)
📄
builddovecotconf
(6.76 KB)
📄
buildeximconf
(7 KB)
📄
buildhttpdconf
(2.6 KB)
📄
buildnsdconf
(1.01 KB)
📄
buildpureftproot
(539 B)
📄
ccs-check
(4.91 KB)
📄
check_cpanel_pkgs
(10.75 KB)
📄
check_cpanel_rpms
(218 B)
📄
check_domain_tls_service_domains.pl
(6.68 KB)
📄
check_immutable_files
(5.49 KB)
📄
check_mail_spamassassin_compiledregexps_body_0
(187 B)
📄
check_maxmem_against_domains_count
(3.57 KB)
📄
check_mount_procfs
(2.02 KB)
📄
check_mysql
(5.55 KB)
📄
check_security_advice_changes
(8.28 KB)
📄
check_unmonitored_enabled_services
(4.56 KB)
📄
check_unreliable_resolvers
(3.59 KB)
📄
check_users_my_cnf
(6.05 KB)
📄
check_valid_server_hostname
(7.66 KB)
📄
checkalldomainsmxs
(2.4 KB)
📄
checkbashshell
(1.18 KB)
📄
checkccompiler
(1.22 KB)
📄
checkexim.pl
(3.1 KB)
📄
checklink
(1.29 KB)
📄
checknsddirs
(1014 B)
📄
checkusers
(856 B)
📄
chkmydns
(561 B)
📄
chkpaths
(141 B)
📄
chpass
(416 B)
📄
ckillall
(1.11 KB)
📄
clean_dead_mailman_locks
(2.09 KB)
📄
clean_up_temp_wheel_users
(2.44 KB)
📄
clean_user_php_sessions
(4.76 KB)
📄
cleandns
(13.09 KB)
📄
cleandns8
(417 B)
📄
cleanmsglog
(735 B)
📄
cleanphpsessions
(932 B)
📄
cleanphpsessions.php
(658 B)
📄
cleanquotas
(1.61 KB)
📄
cleansessions
(5.91 KB)
📄
cleanupinterchange
(2.64 KB)
📄
cleanupmysqlprivs
(533 B)
📄
clear_cpaddon_ui_caches
(1.27 KB)
📄
clear_orphaned_virtfs_mounts
(3.56 KB)
📄
comparecdb
(1.52 KB)
📄
compilers
(2.86 KB)
📄
compilerscheck
(999 B)
📄
configure_firewall_for_cpanel
(520 B)
📄
configure_rh_firewall_for_cpanel
(520 B)
📄
configure_rh_ipv6_firewall_for_cpanel
(520 B)
📄
convert2dovecot
(682 B)
📄
convert_accesshash_to_token
(4.07 KB)
📄
convert_and_migrate_from_legacy_backup
(1.97 KB)
📄
convert_maildir_to_mdbox
(1.66 KB)
📄
convert_mdbox_to_maildir
(1.66 KB)
📄
convert_roundcube_mysql2sqlite
(25.28 KB)
📄
convert_to_dovecot_delivery
(4.33 KB)
📄
convert_whmxfer_to_sqlite
(1.46 KB)
📄
copy_user_mail_as_root
(1.25 KB)
📄
copy_user_mail_as_user
(1.34 KB)
📄
cpaddonsup
(3.25 KB)
📄
cpan_config
(2.8 KB)
📁
cpan_sandbox
📄
cpanel_initial_install
(67.36 KB)
📄
cpanelsync
(28.31 KB)
📄
cpanelsync_postprocessor
(1.62 KB)
📄
cpanpingtest
(965 B)
📄
cpbackup
(44.77 KB)
📄
cpbackup_transport_file
(5.65 KB)
📄
cpdig
(1.81 KB)
📄
cpfetch
(1.23 KB)
📄
cphulkdblacklist
(433 B)
📄
cphulkdwhitelist
(1.3 KB)
📄
cpservice
(2.87 KB)
📄
cpuser_port_authority
(19.29 KB)
📄
cpuser_service_manager
(10.85 KB)
📄
createacct
(24.57 MB)
📄
custom_backup_destination.pl.sample
(5.06 KB)
📄
custom_backup_destination.pl.skeleton
(2.84 KB)
📄
dav_change_hostname
(3.57 KB)
📄
dcpumon-wrapper
(850 B)
📄
delpop
(6.2 KB)
📄
detect_env_capabilities
(508 B)
📄
disable_prelink
(2.77 KB)
📄
disable_sqloptimizer
(1.49 KB)
📄
disablefileprotect
(2.09 KB)
📄
distro_changed_hook
(1.16 KB)
📄
dnscluster
(4.44 KB)
📄
dnsqueuecron
(1.29 KB)
📄
dnssec-cluster-keys
(3.75 KB)
📄
dovecot_maintenance
(7.93 KB)
📄
dovecot_set_defaults.pl
(984 B)
📄
dumpcdb
(866 B)
📄
dumpinodes
(687 B)
📄
dumpquotas
(616 B)
📄
dumpstor
(913 B)
📄
ea4_fresh_install
(2.64 KB)
📄
edit_cpanelsync_exclude_list
(2.58 KB)
📄
editquota
(3.44 KB)
📄
elevate-cpanel
(377.87 KB)
📄
email_archive_maintenance
(6.15 KB)
📄
email_hold_maintenance
(1.46 KB)
📄
enable_spf_dkim_globally
(8.83 KB)
📄
enable_sqloptimizer
(1.57 KB)
📄
enablefileprotect
(2.1 KB)
📄
ensure_autoenabled_features
(2.5 MB)
📄
ensure_conf_dir_crt_key
(4.82 KB)
📄
ensure_cpuser_file_ip
(2.55 KB)
📄
ensure_crontab_permissions
(1.08 KB)
📄
ensure_dovecot_memory_limits_meet_minimum
(3.13 KB)
📄
ensure_hostname_resolves
(2.57 KB)
📄
ensure_includes
(601 B)
📄
ensure_vhost_includes
(13.53 KB)
📄
exim_tidydb
(2.96 KB)
📄
eximconfgen
(1.32 KB)
📄
eximstats_spam_check
(867 B)
📄
export_horde_calendars_to_ics
(15.07 KB)
📄
export_horde_contacts_to_vcf
(13.94 KB)
📄
exportmydnsdb
(3.47 KB)
📄
expunge_expired_certificates_from_sslstorage
(3.56 KB)
📄
expunge_expired_pkgacct_sessions
(852 B)
📄
expunge_expired_transfer_sessions
(1.06 KB)
📄
fastmail
(5.16 KB)
📄
featuremod
(1.92 KB)
📄
fetchfile
(422 B)
📄
find_and_fix_rpm_issues
(6.99 KB)
📄
find_outdated_services
(5.41 KB)
📄
find_pids_with_inotify_watch_on_path
(3.66 KB)
📄
fix-cpanel-perl
(28.82 KB)
📄
fix-listen-on-localhost
(3.52 KB)
📄
fix-web-vhost-configuration
(6.15 KB)
📄
fix_addon_permissions
(7.68 KB)
📄
fix_dns_zone_ttls
(1.34 KB)
📄
fix_innodb_tables
(4.05 KB)
📄
fix_pear_registry
(4.07 KB)
📄
fix_reseller_acls
(10.88 KB)
📄
fixetchosts
(4.32 KB)
📄
fixheaders
(572 B)
📄
fixmailinglistperms
(1008 B)
📄
fixmailman
(2.09 KB)
📄
fixnamedviews
(1.22 KB)
📄
fixndc
(413 B)
📄
fixquotas
(17.45 KB)
📄
fixrelayd
(1.74 KB)
📄
fixrndc
(16.48 KB)
📄
fixtar
(503 B)
📄
fixtlsversions
(4.7 KB)
📄
fixvaliases
(2 KB)
📄
fixwebalizer
(966 B)
📄
forcelocaldomain
(895 B)
📄
ftpfetch
(2.2 KB)
📄
ftpquotacheck
(8.31 KB)
📄
ftpsfetch
(2.36 KB)
📄
ftpupdate
(261 B)
📄
gather_update_log_stats
(4.25 KB)
📄
gather_update_logs_setupcrontab
(5.45 KB)
📄
gemwrapper
(1.74 KB)
📄
gencrt
(6.26 KB)
📄
generate_account_suspension_include
(5.7 KB)
📄
generate_google_drive_credentials
(1.11 KB)
📄
generate_google_drive_oauth_uri
(984 B)
📄
generate_maildirsize
(13.94 KB)
📄
gensysinfo
(1.16 KB)
📄
get_locale_from_legacy_name_info
(1.99 KB)
📄
getremotecpmove
(12.67 KB)
📄
grpck
(1.19 KB)
📄
hackcheck
(3.02 KB)
📄
hook
(1.45 KB)
📄
httpspamdetect
(2.66 KB)
📄
hulk-unban-ip
(3.93 MB)
📄
import_exim_data
(8.39 KB)
📄
importmydnsdb
(11.34 KB)
📄
increase_filesystem_limits
(891 B)
📄
initacls
(4.99 KB)
📄
initfpsuexec
(444 B)
📄
initquotas
(19.47 KB)
📄
initsuexec
(4.03 KB)
📄
install_cpanel_analytics
(1.93 KB)
📄
install_dovecot_fts
(1.57 KB)
📄
install_plugin
(2.8 KB)
📄
installpkg
(575 B)
📄
installpostgres
(6.56 KB)
📄
installsqlite3
(1.82 KB)
📄
ipcheck
(3.93 KB)
📄
ipusage
(7.45 KB)
📄
isdedicatedip
(602 B)
📄
jetbackup-check
(3.69 KB)
📄
killdns
(422 B)
📄
killdns-dnsadmin
(1.15 KB)
📄
killmysqluserprivs
(433 B)
📄
killmysqlwildcard
(1.15 KB)
📄
killpvhost
(853 B)
📄
killspamkeys
(937 B)
📄
link_3rdparty_binaries
(1.24 KB)
📄
linksubemailtomainacct
(3.17 KB)
📄
listcheck
(538 B)
📄
listsubdomains
(1.05 KB)
📄
litespeed-check
(3.86 KB)
📄
locale_export
(4.82 KB)
📄
locale_import
(4.35 KB)
📄
locale_info
(3.99 KB)
📄
logo.dat
(205 B)
📄
magicloader
(1.94 KB)
📄
maildir_converter
(6.08 KB)
📄
mailperm
(16.58 KB)
📄
mailscannerupdate
(2.42 KB)
📄
mainipcheck
(10 KB)
📄
maintenance
(46.62 KB)
📄
make_config
(407 B)
📄
make_hostname_unowned
(1.16 KB)
📄
manage_extra_marketing
(12.41 KB)
📄
manage_greylisting
(16.19 KB)
📄
manage_mysql_profiles
(20.02 KB)
📄
migrate-pdns-conf
(9.83 KB)
📄
migrate_local_ini_to_php_ini
(7.41 KB)
📄
migrate_whmtheme_file_to_userdata
(2.95 KB)
📄
mkwwwacctconf
(2.33 KB)
📄
modify_accounts
(4.09 KB)
📄
modify_featurelist
(9.2 KB)
📄
modify_packages
(3.65 KB)
📄
modsec_vendor
(15.63 KB)
📄
mysqlconnectioncheck
(6.55 KB)
📄
mysqlpasswd
(4.09 KB)
📄
named.ca
(1.57 KB)
📄
named.rfc1912.zones
(774 B)
📄
nixstatsagent.sh
(58.67 KB)
📄
notify_expiring_certificates
(9.37 KB)
📄
notify_expiring_certificates_on_linked_nodes
(1.33 KB)
📄
oopscheck
(1.12 KB)
📄
optimize_eximstats
(3.88 KB)
📄
patch_mail_spamassassin_compiledregexps_body_0
(2.39 KB)
📄
patchfdsetsize
(2.72 KB)
📄
pedquota
(2.26 KB)
📄
perform_sqlite_auto_rebuild_db_maintenance
(2.2 KB)
📄
perlinstaller
(528 B)
📄
perlmods
(1.18 KB)
📄
php_fpm_config
(9.73 KB)
📁
php_sandbox
📄
phpini_tidy
(687 B)
📄
pkgacct
(87.82 KB)
📄
post_snapshot
(3.16 KB)
📄
post_sync_cleanup
(6.09 KB)
📄
primary_virtual_host_migration
(2.44 KB)
📄
process_pending_cpanel_php_pear_registration
(3.49 KB)
📄
process_site_templates
(7.27 KB)
📄
proxydomains
(9.34 KB)
📄
ptycheck
(724 B)
📄
purge_modsec_log
(1.53 KB)
📄
purge_old_config_caches
(2.08 KB)
📄
pwck
(708 B)
📄
quickdnslookup
(1.13 KB)
📄
quickwhoisips
(2.29 KB)
📄
quota_auto_fix
(1.41 KB)
📄
quotacheck
(22.36 KB)
📄
rawchpass
(460 B)
📄
rdate
(4.8 KB)
📄
realadduser
(5.61 KB)
📄
realchpass
(3.26 KB)
📄
realperlinstaller
(5.67 KB)
📄
realrawchpass
(425 B)
📄
rebuild_available_addons_packages_cache
(1.27 KB)
📄
rebuild_available_rpm_addons_cache
(1.27 KB)
📄
rebuild_bandwidthdb_root_cache
(1.45 KB)
📄
rebuild_dbmap
(5.8 KB)
📄
rebuild_provider_openid_connect_links_db
(1.01 KB)
📄
rebuild_whm_chrome
(2.22 KB)
📄
rebuilddnsconfig
(26.21 KB)
📄
rebuildhttpdconf
(2.6 KB)
📄
rebuildinstalledssldb
(2.85 KB)
📄
rebuildippool
(509 B)
📄
rebuildnsdzones
(1.14 KB)
📄
rebuilduserssldb
(948 B)
📄
refresh-dkim-validity-cache
(5.97 KB)
📄
regenerate_tokens
(2.18 KB)
📄
reloadnsd
(821 B)
📄
remote_log_transfer
(11.6 KB)
📄
remove_dovecot_index_files
(5.89 KB)
📄
removeacct
(20.91 MB)
📄
rescan_user_dovecot_fts
(2.98 KB)
📄
reset_mail_quotas_to_sane_values
(6.82 KB)
📄
resetmailmanurls
(2.03 KB)
📄
resetquotas
(4.68 KB)
📄
restartsrv
(3.23 KB)
📄
restartsrv_apache
(422 B)
📄
restartsrv_apache_php_fpm
(9.9 MB)
📄
restartsrv_base
(9.9 MB)
📄
restartsrv_bind
(9.9 MB)
📄
restartsrv_chkservd
(427 B)
📄
restartsrv_clamd
(9.9 MB)
📄
restartsrv_cpanalyticsd
(9.9 MB)
📄
restartsrv_cpanel_php_fpm
(9.9 MB)
📄
restartsrv_cpanellogd
(9.9 MB)
📄
restartsrv_cpdavd
(9.9 MB)
📄
restartsrv_cpgreylistd
(9.9 MB)
📄
restartsrv_cphulkd
(9.9 MB)
📄
restartsrv_cpipv6
(9.9 MB)
📄
restartsrv_cpsrvd
(9.9 MB)
📄
restartsrv_crond
(9.9 MB)
📄
restartsrv_dnsadmin
(9.9 MB)
📄
restartsrv_dovecot
(9.9 MB)
📄
restartsrv_exim
(9.9 MB)
📄
restartsrv_eximstats
(504 B)
📄
restartsrv_ftpd
(426 B)
📄
restartsrv_ftpserver
(911 B)
📄
restartsrv_httpd
(9.9 MB)
📄
restartsrv_imap
(437 B)
📄
restartsrv_inetd
(2.47 KB)
📄
restartsrv_ipaliases
(9.9 MB)
📄
restartsrv_lmtp
(437 B)
📄
restartsrv_mailman
(9.9 MB)
📄
restartsrv_mydns
(9.9 MB)
📄
restartsrv_mysql
(9.9 MB)
📄
restartsrv_named
(777 B)
📄
restartsrv_nscd
(9.9 MB)
📄
restartsrv_nsd
(9.9 MB)
📄
restartsrv_p0f
(9.9 MB)
📄
restartsrv_pdns
(9.9 MB)
📄
restartsrv_pop3
(437 B)
📄
restartsrv_postgres
(427 B)
📄
restartsrv_postgresql
(9.9 MB)
📄
restartsrv_powerdns
(442 B)
📄
restartsrv_proftpd
(9.9 MB)
📄
restartsrv_pureftpd
(9.9 MB)
📄
restartsrv_queueprocd
(9.9 MB)
📄
restartsrv_rsyslog
(9.9 MB)
📄
restartsrv_rsyslogd
(437 B)
📄
restartsrv_spamd
(9.9 MB)
📄
restartsrv_sshd
(9.9 MB)
📄
restartsrv_syslogd
(2.4 KB)
📄
restartsrv_tailwatchd
(9.9 MB)
📄
restartsrv_unknown
(9.9 MB)
📄
restartsrv_xinetd
(422 B)
📄
restorecpuserfromcache
(1.96 KB)
📄
restorepkg
(36.49 MB)
📄
rfc1912_zones.tar
(10 KB)
📄
rpmup
(4.77 KB)
📄
rsync-user-homedir.pl
(5.76 KB)
📄
run_if_exists
(512 B)
📄
run_plugin_lifecycle
(3.53 KB)
📄
runstatsonce
(440 B)
📄
runweblogs
(1.02 KB)
📄
sa-update_wrapper
(3.34 KB)
📄
safetybits.pl
(844 B)
📄
secureit
(4.72 KB)
📄
securemysql
(4.54 KB)
📄
securerailsapps
(3.58 KB)
📄
securetmp
(15.99 KB)
📄
sendicq
(474 B)
📄
servicedomains
(9.34 KB)
📄
set_mailman_archive_perms
(1.75 KB)
📄
set_php_memory_limits
(3.67 KB)
📄
setpostgresconfig
(6.04 KB)
📄
setup_greylist_db
(16.19 KB)
📄
setup_modsec_db
(1.3 KB)
📄
setup_systemd_timer_for_plugins
(3.92 KB)
📄
setupftpserver
(10.47 KB)
📄
setupmailserver
(9.55 KB)
📄
setupnameserver
(13.75 KB)
📄
shrink_modsec_ip_database
(12.97 KB)
📄
simpleps
(3.05 KB)
📄
slurp_exim_mainlog
(5.78 KB)
📄
smartcheck
(15.13 KB)
📄
smtpmailgidonly
(8.15 KB)
📄
snapshot_prep
(5.88 KB)
📄
spamassassin_dbm_cleaner
(5.85 KB)
📄
spamassassindisable
(3.74 KB)
📄
spamboxdisable
(2.27 KB)
📄
sshcontrol
(14.38 KB)
📄
ssl_crt_status
(3.84 KB)
📄
suspendacct
(18.01 KB)
📄
suspendmysqlusers
(4.42 KB)
📄
swapip
(3.82 KB)
📄
sync-mysql-users-from-grants
(1.2 KB)
📄
sync_child_accounts
(1.77 KB)
📄
sync_contact_emails_to_cpanel_users_files
(1.14 KB)
📄
synccpaddonswithsqlhost
(6.59 KB)
📄
synctransfers
(1.92 KB)
📄
syslog_check
(1.36 KB)
📄
sysup
(645 B)
📄
test_sa_compiled
(1.07 KB)
📄
transfer_account_as_user
(2.34 KB)
📄
transfer_accounts_as_root
(4.76 KB)
📄
transfer_in_progress
(3.08 KB)
📄
transfer_in_progress.pod
(312 B)
📄
transfermysqlusers
(9.53 MB)
📄
try-later
(7.95 KB)
📄
unblockip
(667 B)
📄
uninstall_cpanel_analytics
(1.2 KB)
📄
uninstall_dovecot_fts
(562 B)
📄
uninstall_plugin
(2.84 KB)
📄
unlink_service_account
(2.62 KB)
📄
unpkgacct
(4.6 KB)
📄
unslavenamedconf
(863 B)
📄
unsuspendacct
(17.8 KB)
📄
unsuspendmysqlusers
(6.71 KB)
📄
upcp
(31.56 KB)
📄
upcp-running
(2.7 KB)
📄
upcp.static
(708.6 KB)
📄
update-packages
(4.77 KB)
📄
update_apachectl
(480 B)
📄
update_db_cache
(430 B)
📄
update_dkim_keys
(1.45 KB)
📄
update_exim_rejects
(1.21 KB)
📄
update_existing_mail_quotas_for_account
(4.78 KB)
📄
update_known_proxy_ips
(1002 B)
📄
update_local_rpm_versions
(4.56 KB)
📄
update_mailman_cache
(8.34 KB)
📄
update_mysql_systemd_config
(1.25 KB)
📄
update_neighbor_netblocks
(487 B)
📄
update_sa_config
(2.14 KB)
📄
update_spamassassin_config
(10.73 KB)
📄
update_users_jail
(691 B)
📄
update_users_vhosts
(801 B)
📄
updatedomainips
(605 B)
📄
updatenameserverips
(1.66 KB)
📄
updatenow
(5.18 KB)
📄
updatenow.static
(1.91 MB)
📄
updatesigningkey
(1.95 KB)
📄
updatessldomains
(1.81 KB)
📄
updatesupportauthorizations
(2.49 KB)
📄
updateuserdatacache
(2.47 KB)
📄
updateuserdomains
(774 B)
📄
upgrade_bandwidth_dbs
(2.22 KB)
📄
upgrade_subaccount_databases
(2.73 KB)
📄
userdata_wildcard_cleanup
(5.74 KB)
📄
userdirctl
(5.01 KB)
📄
validate_sshkey_passphrase
(1.21 KB)
📄
verify_api_spec_files
(757 B)
📄
verify_pidfile
(1.96 KB)
📄
verify_vhost_includes
(7.34 KB)
📄
vps_optimizer
(7.82 KB)
📄
vzzo-fixer
(725 B)
📄
whmlogin
(2.33 KB)
📄
whoowns
(1.13 KB)
📄
wpt_license
(6.27 MB)
📄
wwwacct
(24.57 MB)
📄
wwwacct2
(88 B)
📄
xfer_rcube_schema_migrate.pl
(2.4 KB)
📄
xfer_rcube_uid_resolver.pl
(1.8 KB)
📄
xferpoint
(3.13 KB)
📄
xfertool
(16.14 KB)
📄
zoneexists
(800 B)
Editing: rebuilddnsconfig
#!/usr/local/cpanel/3rdparty/bin/perl # cpanel - scripts/rebuilddnsconfig Copyright 2022 cPanel, L.L.C. # All rights reserved. # copyright@cpanel.net http://cpanel.net # This code is subject to the cPanel license. Unauthorized copying is prohibited use strict; use warnings; use Cpanel::DNSLib (); use Cpanel::OS (); use Cpanel::FileUtils::Move (); use Cpanel::FileUtils::Copy (); use Cpanel::Path (); use Cpanel::StringFunc::Count (); use Cpanel::StringFunc::Match (); use Cpanel::SafetyBits (); use Cpanel::NameServer::Conf (); use Cpanel::NameServer::Utils::BIND (); use Cpanel::Validate::Domain::Tiny (); use Cpanel::DNSLib (); use Getopt::Std; $Getopt::Std::STANDARD_HELP_VERSION = 1; umask 0022; ######[ declare some globals ]##################################################################### # default location of zone files used for rebuilding named.conf my $def_basedir; # default location of named.conf my $def_namedconf; # default log directory for named my $def_logdir; # default location of pidfile my $def_pidfile = '/var/run/named/named.pid'; # Verbose variable, if set to "1" actions are reported to STDOUT. my $cpverbose = 0; # We sent this to fixrndc, if it sends it back that means we've got a loop my $selfcalled = 0; my %options = (); getopts( 'sfv', \%options ); if ( defined( $options{'v'} ) ) { $cpverbose = 1; } if ( defined( $options{'s'} ) ) { $selfcalled = 1; } if ( $selfcalled == 1 ) { print "Loop detected, exiting.\n"; exit; } ######[ set defaults based on distro/OS ]########################################################## $def_basedir = Cpanel::OS::dns_named_basedir(); # /var/named $def_namedconf = Cpanel::OS::dns_named_conf(); # /etc/named.conf $def_logdir = Cpanel::OS::dns_named_log(); # /var/log/named ######[ ensure base directory structure is created ]############################################### my ( $chrootdir, $binduser, $bindgroup ) = Cpanel::NameServer::Utils::BIND::find_chrootbinddir(); my $binduid = getpwnam($binduser) || die "$binduser not in passwd file"; my $bindgid = getgrnam($bindgroup) || die "$bindgroup not configured on the system"; # Set up directory structure if ( !-e $def_basedir ) { mkdir $def_basedir or die "Unable to create $def_basedir: $!"; chown $binduid, $bindgid, $def_basedir; } if ( !-e "$def_basedir/data" ) { mkdir "$def_basedir/data" or die "Unable to create $def_basedir/data: $!"; chown $binduid, $bindgid, "$def_basedir/data"; } if ( !-e $def_logdir ) { mkdir $def_logdir or die "Unable to create $def_logdir: $!"; chown $binduid, $bindgid, $def_logdir; } # Set up pid directory if ( !-e '/var/run/named' ) { mkdir '/var/run/named' or die "Unable to create '/var/run/named': $!"; } chown $binduid, $bindgid, '/var/run/named'; # create base chroot directories if required if ($chrootdir) { if ( !-e $chrootdir . '/etc' ) { mkdir $chrootdir . '/etc' or die "Unable to create $chrootdir/etc: $!"; } if ( !-e $chrootdir . '/var' ) { mkdir $chrootdir . '/var' or die "Unable to create $chrootdir/var: $!"; } if ( !-e $chrootdir . '/var/named' ) { mkdir $chrootdir . '/var/named' or die "Unable to create $chrootdir/var/named: $!"; } if ( !-e $chrootdir . '/var/named/data' ) { mkdir $chrootdir . '/var/named/data' or die "Unable to create $chrootdir/var/named/data: $!"; } chown $binduid, $bindgid, $chrootdir . '/var/named/data'; if ( !-e $chrootdir . '/var/run' ) { mkdir $chrootdir . '/var/run' or die "Unable to create $chrootdir/var/run: $!"; } if ( !-e $chrootdir . '/var/run/named' ) { mkdir $chrootdir . '/var/run/named' or die "Unable to create $chrootdir/var/run/named: $!"; } chown $binduid, $bindgid, $chrootdir . '/var/run/named'; } ######[ Setup Hint zone file if needed ]########################################################### if ( !-e "$def_basedir/named.ca" ) { Cpanel::FileUtils::Copy::safecopy( '/usr/local/cpanel/scripts/named.ca', "$def_basedir/named.ca" ); } if ( !-e "$def_basedir/localdomain.zone" || !-e "$def_basedir/localdomain.zone" || !-e "$def_basedir/named.broadcast" || !-e "$def_basedir/named.ip6.local" || !-e "$def_basedir/named.local" || !-e "$def_basedir/named.zero" || !-e "$def_basedir/named.rfc1912.zones" ) { # RFC1912 Cpanel::FileUtils::Copy::safecopy( '/usr/local/cpanel/scripts/named.rfc1912.zones', "$def_basedir/named.rfc1912.zones" ); system 'tar', 'xvf', '/usr/local/cpanel/scripts/rfc1912_zones.tar', '-C', $def_basedir; # uses new .tar without the ./named/ directory so we can use it for both if ($chrootdir) { system 'tar', 'xvf', '/usr/local/cpanel/scripts/rfc1912_zones.tar', '-C', $chrootdir . '/var/named'; } } ######[ create a brand new named.conf from a default template if needed ]########################## if ( !-e $def_namedconf || -z _ ) { # no named.conf or zero bytes print "Installing default Bind configuration\n" if $cpverbose; #>>>>>[ Write default configuration w/ proper basedir ]>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> if ( open my $conf_fh, '>', $def_namedconf ) { foreach (&getdefault_nameddotconf) { s/###BASE_DIR###/$def_basedir/g; s/###PID_FILE###/$def_pidfile/g; print {$conf_fh} $_; } close $conf_fh; } clearcache(); # Reset ownership Cpanel::SafetyBits::safe_recchown( 'named', 'named', $def_basedir ); # Force $options{'f'} = 1; } my $dnslib = Cpanel::DNSLib->new(); my $needpid = 0; ######[> Ensure all .db's have an entry in named.conf and vice versa >]############################ # suck up all zones of the named.conf and zone dir in memory for fast parsing, heavy on mem side but better than thrashing hdd my %needtoadd; my $ndc_fh; my $namedconf_obj = Cpanel::NameServer::Conf->new(); $namedconf_obj->checkcache(); # start with a freshly rebuild conf file when force is specified (also happens when named.conf was empty) if ( $options{'f'} && $namedconf_obj->type() ne 'bind' ) { $namedconf_obj->rebuild_conf(); } my %current_zone_entries = map { $_ => 1 } @{ $namedconf_obj->fetchzones() }; opendir my $zone_dh, $def_basedir or die "Unable to read zone file directory $def_basedir: $!"; my @zonedir_contents = readdir($zone_dh); closedir $zone_dh; my %current_zone_files = (); foreach my $zonefile (@zonedir_contents) { if ( $zonefile =~ /^([\w\-.]+)\.db$/ && Cpanel::Validate::Domain::Tiny::validdomainname($1) ) { $current_zone_files{$1} = 1; } } my %bad_zones = %current_zone_entries; delete @bad_zones{ keys %current_zone_files }; delete $bad_zones{'.'}; my %missing_zones = %current_zone_files; delete @missing_zones{ keys %current_zone_entries }; # make sure all zones.db files have entry in named.conf # Add missing files to named.conf if ( scalar keys %missing_zones ) { print "Adding zones " . join( ' ', keys %missing_zones ) . "\n" if $cpverbose; $namedconf_obj->addzones( keys %missing_zones ); } # make sure all entries in named.conf have zone files if ( scalar keys %bad_zones ) { print 'Removing zones ' . join( ' ', keys %bad_zones ) . " from configuration, zonefiles missing\n" if $cpverbose; $namedconf_obj->removezones( keys %bad_zones ); } $namedconf_obj->finish(); ######[> Handle chroot setups >]################################################################### # This logic is required due to how bind-chroot symlinks /etc/named.conf to the chroot location # And how File::Copy will not follow the symlinks, but will recreate them instead if ( -l $def_namedconf ) { my $target = readlink $def_namedconf; print "Symlink detected: $target\n"; if ( open( $ndc_fh, '<', $target ) ) { unlink $def_namedconf; print "Restoring $def_namedconf from $target before proceeding\n"; Cpanel::FileUtils::Copy::safecopy( $target, $def_namedconf ); } else { print "Failed to read symlinked $def_namedconf [$target]. Cannot continue.\n"; exit 1; } } else { open( $ndc_fh, "<", $def_namedconf ); } open( my $ndf_fh, ">", $def_namedconf . '.rebuilddnsconfig' ); if ( !$ndc_fh ) { open( $ndc_fh, "<", $def_namedconf ); } my $inc = 0; my $firstline = 0; my $numbrace = 0; my $zonemarker = 0; my $cppcomment = 0; my $currzone = ''; my $skip_next_opening = 0; my $zonedir = Cpanel::DNSLib::find_zonedir(); while (<$ndc_fh>) { # Rudamentary comment exclusion. if ($cppcomment) { if (m/\*\//) { $cppcomment = 0; } print $ndf_fh $_; next; } if (m/^\s*\#/) { print $ndf_fh $_; next; } if (m/^\s*\/\//) { print $ndf_fh $_; next; } if (m/^\s*\/\*/) { $cppcomment = 1; print $ndf_fh $_; next; } if ( $skip_next_opening && m/^\s*\{\s*$/ ) { $skip_next_opening = 0; $numbrace++; next; } next if m/bind.conf.wp/; next if ( m/\s*include\s+/ && m/rndc.key/ ); if ( $needpid && m/pid-file/ ) { next; } if (m/\s*zone\s+["']([^"']+)/) { $zonemarker = 1; $currzone = $1; } elsif (m/\s*include\s+["']([^"']+)/) { my $file = $1; my $filemtime = ( stat($file) )[9]; if ( -f _ ) { copytochroot( $file, $filemtime ); } } if ($zonemarker) { $numbrace += Cpanel::StringFunc::Count::get_curly_brace_count($_); if ( $numbrace == 0 ) { $zonemarker = 0; } if (m/(.*[\s\t\;\{])file\s+(["'])([^"']+)(.*)/) { my $postfile = $4; my $file = $3; my $prefile = $2; my $space = $1; my $relativedir = ''; my $fileold = $file; if ( !Cpanel::StringFunc::Match::beginmatch( $file, '/' ) ) { if ( $file =~ m/^([^\/]+)/ ) { $relativedir = $1; } } my $filename = $file; if ( $file =~ m/([^\/]+)$/ ) { $filename = $1; } my $filenew = $zonedir . '/' . $filename; if ( $file eq $filenew ) { print $ndf_fh $_; } elsif ( !Cpanel::StringFunc::Match::beginmatch( $file, '/' ) ) { $file = $filenew; print "Updating $fileold to $filenew\n"; #print $ndf_fh "${space}file ${prefile}${filenew}${postfile}"; } else { if ( !Cpanel::StringFunc::Match::beginmatch( $file, '/dev/' ) ) { $filenew = $zonedir . '/' . $filename; print "Updating $file to $filenew\n"; #print $ndf_fh "${space}file ${prefile}${filenew}${postfile}"; } else { $filenew = $file; print $ndf_fh $_; } } my $absfilename = ''; if ( $relativedir ne '' ) { $absfilename = Cpanel::Path::relative2abspath( $relativedir, $zonedir ) . '/' . $filename; } if ( $absfilename ne '' && -e $absfilename ) { $file = $absfilename; } my ( $fileinode, $filemtime ) = stat($file); my ( $filenewinode, $filenewmtime ) = stat($filenew); if ( !$filemtime && $currzone eq '.' ) { next if ($filenewmtime); $file = '/usr/local/cpanel/scripts/named.ca'; ( $fileinode, $filemtime ) = stat($file); print "Root hints zone missing. Using default.\n" if $cpverbose; } elsif ( !$filemtime ) { print "!! $file does not exist, unable to locate.\n"; print "!! Run /usr/local/cpanel/scripts/cleandns to remove zone without corresponding files.\n"; print "!! Or locate the proper zone file and place in $zonedir and rerun\n"; print "!! This script with the following options: /script/fixndc -fv\n"; next; } if ( !$filenewmtime ) { print "Moving $file to $filenew ...\n"; Cpanel::FileUtils::Move::safemv( $file, $filenew ); } elsif ( $fileinode != $filenewinode && ( $filenewmtime > time() || $filemtime > $filenewmtime ) ) { # timewarp safe Cpanel::FileUtils::Copy::safecopy( $file, $filenew ); Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $filenew ); } copytochroot( $filenew, $filemtime ); next; } } # Match for zone and file declaration on one line. if ( m/.*[\s\t\;\{]file\s+["'][^"']+/ && m/[\s\;]*zone/ ) { m/(.*[\s\t\;\{])file\s+["']([^"']+)(.*)/; my $file = $2; my $space = $1; my $space2 = $3; my $relativedir = ''; my $currzone = ''; my $delim = '"'; if (m/\s*zone\s+(["'])([\w\-\.]+)["']/) { $zonemarker = 1; $currzone = $2; $delim = $1; } m/zone\s+(.*)/; $numbrace += Cpanel::StringFunc::Count::get_curly_brace_count($1); if ( $numbrace <= 0 ) { $zonemarker = 0; } if ( !Cpanel::StringFunc::Match::beginmatch( $file, '/' ) ) { if ( $file =~ m/^([^\/]+)/ ) { $relativedir = $1; } } my $filename = $file; if ( $file =~ m/([^\/]+)$/ ) { $filename = $1; } my $filenew = $zonedir . '/' . $filename; if ( $file eq $filenew ) { print $ndf_fh $_; } elsif ( !Cpanel::StringFunc::Match::beginmatch( $file, '/' ) ) { $file = $filenew; print "Updating $file to $filenew\n"; #print $ndf_fh "${space}file ${delim}${filenew}${space2}"; } else { if ( !Cpanel::StringFunc::Match::beginmatch( $file, '/dev/' ) ) { $filenew = $zonedir . '/' . $filename; print "Updating $file to $filenew\n"; #print $ndf_fh "${space}file ${delim}${filenew}${space2}"; } else { $filenew = $file; print $ndf_fh $_; } } my $absfilename = ''; if ($relativedir) { $absfilename = Cpanel::Path::relative2abspath( $relativedir, $zonedir ) . '/' . $filename; } if ( $absfilename ne '' && -e $absfilename ) { $file = $absfilename; } my $mtime = 0; if ( -e $file ) { $mtime = ( stat(_) )[9]; if ( !-e $filenew ) { print "Moving $file to $filenew ...\n"; Cpanel::FileUtils::Move::safemv( $file, $filenew ); } elsif (( stat($file) )[1] != ( stat($filenew) )[1] && ( ( stat($filenew) )[9] > time() || $mtime > ( stat($filenew) )[9] ) ) { # timewarp safe Cpanel::FileUtils::Copy::safecopy( $file, $filenew ); Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $filenew ); } } elsif ( $currzone eq '.' ) { next if ( -e $filenew ); $file = '/usr/local/cpanel/scripts/named.ca'; print "Root hints zone missing. Using default.\n" if $cpverbose; if ( !-e $filenew ) { print "Moving $file to $filenew ...\n"; Cpanel::FileUtils::Move::safemv( $file, $filenew ); } elsif (( stat($file) )[1] != ( stat($filenew) )[1] && ( ( stat($filenew) )[9] > time() || $mtime > ( stat($filenew) )[9] ) ) { # timewarp safe Cpanel::FileUtils::Copy::safecopy( $file, $filenew ); Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $filenew ); } } else { print "!! $file does not exist, unable to locate.\n"; print "!! Run /usr/local/cpanel/scripts/cleandns to remove zone without corresponding files.\n"; print "!! Or locate the proper zone file and place in $zonedir and rerun\n"; print "!! This script with the following options: /script/fixndc -fv\n"; $filenew = ''; } if ( $filenew ne '' ) { copytochroot( $filenew, $mtime ); } } if ( !$inc ) { print $ndf_fh $_; } else { if ($firstline) { $firstline = 0; next; } $numbrace += Cpanel::StringFunc::Count::get_curly_brace_count($_); if ( $numbrace == 0 ) { $inc = 0; } } if ( $needpid && m/^\s*options\s*/ ) { if ( !m/\{/ ) { #print $ndf_fh "{\n\tpid-file \"/var/run/named/pid\"\;\n"; $skip_next_opening = 1; } else { #print $ndf_fh "\tpid-file \"/var/run/named/pid\"\;\n"; } next; } } close $ndc_fh; close $ndf_fh; Cpanel::FileUtils::Copy::safecopy( $def_namedconf, $def_namedconf . '.prerebuilddnsconfig' ); clearcache(); Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $def_namedconf ); if ( $chrootdir ne '' ) { print "Updated $def_namedconf in chroot directory\n" if $cpverbose; if ( -e $chrootdir . $def_namedconf ) { if ( ( stat($def_namedconf) )[1] != ( stat( $chrootdir . $def_namedconf ) )[1] ) { Cpanel::FileUtils::Copy::safecopy( $def_namedconf, $chrootdir . $def_namedconf ); Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $chrootdir . $def_namedconf ); } } else { Cpanel::FileUtils::Copy::safecopy( $def_namedconf, $chrootdir . $def_namedconf ); Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $chrootdir . $def_namedconf ); } } # Reset ownership of named.conf print "Changing ownership of $def_namedconf: $binduser:$bindgroup\n" if $cpverbose; Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $def_namedconf ); if ( !-e '/var/cpanel/usensd' ) { print "Restarting Bind\n" if $cpverbose; system('/usr/local/cpanel/scripts/restartsrv_named'); } else { # This will also regenerate the zone database print "Restarting NSD\n" if $cpverbose; system('/usr/local/cpanel/scripts/restartsrv_nsd'); } ######[ call fixrndc to ensure working rndckey config ]############################################ if ( !-e '/var/cpanel/usensd' ) { print "Running `/usr/local/cpanel/scripts/fixrndc -f` to check rndc key\n" if $cpverbose; my $opts = $cpverbose ? '-fvs' : '-fs'; exec( '/usr/local/cpanel/scripts/fixrndc', $opts ); } exit(0); ################################################################################ # sub copytochroot ################################################################################ sub copytochroot { my $filenew = shift; # mtime of original file my $mtime = shift || 0; if ( $chrootdir ne '' ) { my $chrootfile = $chrootdir . $filenew; print "Copying $filenew to $chrootfile\n" if $cpverbose; my ( $fsinode, $fsmode, $fsuid, $fsgid, $fsmtime ) = ( stat($filenew) )[ 1, 2, 4, 5, 9 ]; my $fsperms = $fsmode & 07777; if ( -e $chrootfile ) { my ( $chrootinode, $chrootmode, $chrootuid, $chrootgid, $chrootmtime ) = ( stat(_) )[ 1, 2, 4, 5, 9 ]; my $chrootperms = $chrootmode & 07777; if ($mtime) { my $now = time(); if ( $fsinode != $chrootinode && ( $mtime > $chrootmtime || $mtime > $now || $chrootmtime > $now || $chrootuid != $binduid || $chrootgid != $bindgid || $chrootperms != $fsperms ) ) { #timewarp safe if ( Cpanel::FileUtils::Copy::safecopy( $filenew, $chrootfile ) ) { print "Copied $filenew to chroot environment.\n" if $cpverbose; Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $chrootfile ); Cpanel::SafetyBits::safe_chmod( $fsperms, $chrootfile ); return 1; } else { warn "Problem copying $filenew to $chrootdir"; return 0; } } else { print "$filenew already exists in chroot environment.\n" if $cpverbose; return 1; } } else { if ( $fsinode != $chrootinode ) { if ( Cpanel::FileUtils::Copy::safecopy( $filenew, $chrootfile ) ) { Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $chrootfile ); Cpanel::SafetyBits::safe_chmod( $fsperms, $chrootfile ); print "Copied $filenew to chroot environment.\n" if $cpverbose; return 1; } else { warn "Problem copying $filenew to $chrootdir"; return 0; } } else { if ( $chrootuid != $binduid || $chrootgid != $bindgid || $chrootperms != $fsperms ) { Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $chrootfile ); Cpanel::SafetyBits::safe_chmod( $fsperms, $chrootfile ); } print "$filenew already exists in chroot environment.\n" if $cpverbose; return 1; } } warn "Problem copying $filenew to chroot environment. This should not happen."; return 0; } elsif ( Cpanel::FileUtils::Copy::safecopy( $filenew, $chrootfile ) ) { print "Copied $filenew to chroot environment.\n" if $cpverbose; Cpanel::SafetyBits::safe_chown( $binduser, $bindgroup, $chrootfile ); return 1; } else { warn "Problem copying $filenew to chroot environment.\n"; return 0; } } return 0; } sub clearcache { if ( -e $def_namedconf . '.cache' ) { unlink( $def_namedconf . '.cache' ); unlink( $def_namedconf . '.zonedir.cache' ); } } ######[ Default named.conf template ]############################################################## sub getdefault_nameddotconf { my $bind_ipv6_line = ''; if ( -f '/etc/cpanel/ipv6/range_allocation_data' ) { $bind_ipv6_line = "\n\ // Enable IPv6\n listen-on-v6 { any; }; /* updated by cPanel */"; } return <<"EOC"; options { /* make named use port 53 for the source of all queries, to allow * firewalls to block all ports except 53: */ // query-source port 53; $bind_ipv6_line recursion no; /* We no longer enable this by default as the dns posion exploit has forced many providers to open up their firewalls a bit */ // Put files that named is allowed to write in the data/ directory: directory "###BASE_DIR###"; // the default pid-file "###PID_FILE###"; dump-file "data/cache_dump.db"; statistics-file "data/named_stats.txt"; /* memstatistics-file "data/named_mem_stats.txt"; */ allow-transfer { "none"; }; }; logging { channel default_log { file "/var/log/named/named.log" versions 5 size 128M; print-time yes; print-severity yes; print-category yes; severity warning; }; category default { default_log; }; category general { default_log; }; }; // All BIND 9 zones are in a "view", which allow different zones to be served // to different types of client addresses, and for options to be set for groups // of zones. // // By default, if named.conf contains no "view" clauses, all zones are in the // "default" view, which matches all clients. // // If named.conf contains any "view" clause, then all zones MUST be in a view; // so it is recommended to start off using views to avoid having to restructure // your configuration files in the future. view "localhost_resolver" { /* This view sets up named to be a localhost resolver ( caching only nameserver ). * If all you want is a caching-only nameserver, then you need only define this view: */ match-clients { 127.0.0.0/24; }; match-destinations { localhost; }; recursion yes; zone "." IN { type hint; file "###BASE_DIR###/named.ca"; }; /* these are zones that contain definitions for all the localhost * names and addresses, as recommended in RFC1912 - these names should * ONLY be served to localhost clients: */ include "###BASE_DIR###/named.rfc1912.zones"; }; view "internal" { /* This view will contain zones you want to serve only to "internal" clients that connect via your directly attached LAN interfaces - "localnets" . */ match-clients { localnets; }; match-destinations { localnets; }; recursion yes; zone "." IN { type hint; file "###BASE_DIR###/named.ca"; }; // include "###BASE_DIR###/named.rfc1912.zones"; // you should not serve your rfc1912 names to non-localhost clients. // These are your "authoritative" internal zones, and would probably // also be included in the "localhost_resolver" view above : }; view "external" { /* This view will contain zones you want to serve only to "external" clients * that have addresses that are not on your directly attached LAN interface subnets: */ recursion no; additional-from-cache no; // you'd probably want to deny recursion to external clients, so you don't // end up providing free DNS service to all takers // all views must contain the root hints zone: zone "." IN { type hint; file "###BASE_DIR###/named.ca"; }; // These are your "authoritative" external zones, and would probably // contain entries for just your web and mail servers: // BEGIN external zone entries }; EOC } ###################################################################################################
Upload File
Create Folder