#!/usr/local/cpanel/3rdparty/bin/perl
# cpanel - scripts/archive_sync_zones 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 warnings;
use strict;
require Cpanel::Config::Users;
require Cpanel::Config::LoadCpUserFile;
require Cpanel::Umask;
######[ set defaults based on distro/OS ]##########################################################
my $def_basedir = '/var/named';
my $def_namedconf = '/etc/named.conf';
my $def_backup = $def_basedir . '/' . 'zone_sync_backup.tar';
open( my $ndc_fh, '<', $def_namedconf ) or die "Could not open $def_namedconf for reading: $!\n";
my @conf_zones = readline($ndc_fh);
close $ndc_fh;
my %zones;
foreach my $line (@conf_zones) {
if ( $line =~ m/\s*zone\s+["']([\w\-\.]+)["']/ ) {
next if $1 eq '.';
my $zone_name = $1;
next if $zone_name =~ m/^\./;
next if $zone_name =~ m/\.arpa$/;
next if ( exists $zones{$zone_name} ); # Seen in another view
$zones{$zone_name} = 1;
}
}
if ( opendir my $zone_dh, $def_basedir ) {
while ( my $file = readdir $zone_dh ) {
next if $file !~ m/(.+)\.db$/; # Only look at cPanel managed zone file
my $zone_name = $1;
next if $zone_name =~ m/\.arpa$/;
next if exists $zones{$zone_name};
$zones{$zone_name} = 1;
}
closedir $zone_dh;
}
my ( $live_domains, $dead_domains ) = get_domains_managed_domains();
if ( -e $def_backup ) {
require Cpanel::Autodie;
Cpanel::Autodie::chmod( 0600, $def_backup );
}
my $mask = Cpanel::Umask->new(077);
system "tar -cf $def_backup $def_namedconf";
foreach my $zone ( sort keys %zones ) {
next if ( !$live_domains->{$zone} && !$dead_domains->{$zone} );
if ( -e $def_basedir . '/' . $zone . '.db' ) {
system 'tar', '-r', '-f', $def_backup, $def_basedir . '/' . $zone . '.db';
}
else {
print "Unable to archive zone file for $zone\n";
}
system '/usr/local/cpanel/scripts/dnscluster', 'synczone', $zone;
}
print "Archive of pre-sync zones located at: ${def_basedir}/zone_sync_backup.tar\n";
sub get_domains_managed_domains {
my %live_domains;
my %dead_domains;
foreach my $user ( Cpanel::Config::Users::getcpusers() ) {
# Safe because it's only loading from cpusers list.
my $cpuser_ref = Cpanel::Config::LoadCpUserFile::loadcpuserfile($user);
if ( $cpuser_ref->{'DOMAIN'} ) {
$live_domains{ $cpuser_ref->{'DOMAIN'} } = 1;
}
if ( ref $cpuser_ref->{'DOMAINS'} eq 'ARRAY' ) {
my $_tmp = $cpuser_ref->{'DOMAINS'};
$live_domains{$_} = 1 for @$_tmp;
}
if ( ref $cpuser_ref->{'DEADDOMAINS'} eq 'ARRAY' ) {
my $_tmp = $cpuser_ref->{'DEADDOMAINS'};
$dead_domains{$_} = 1 for @$_tmp;
}
}
return ( \%live_domains, \%dead_domains );
}