Finished work on zone generation/writing, adding/removing/getting/setting ptrs and main program flow -hopefully-. Untested as of yet.

This commit is contained in:
Maff 2014-02-09 10:22:06 +00:00
parent f9ea0a8c19
commit cb17b00191
1 changed files with 39 additions and 8 deletions

View File

@ -125,8 +125,10 @@ sub generate_soa_serial {
} }
sub write_zone { sub write_zone {
my $zone = shift; my $zone = shift;
my @z = @_;
foreach(@z) {$_->serial(generate_soa_serial $_->serial) if $_->type eq "SOA";} #update SOA
open ZONE, ">$zone_dir$zone$zone_ext" or nicedie "Failed to open zonefile for $zone for writing!"; open ZONE, ">$zone_dir$zone$zone_ext" or nicedie "Failed to open zonefile for $zone for writing!";
print ZONE Net::DNS::ZoneParse::writezone @_; print ZONE Net::DNS::ZoneParse::writezone @z;
close ZONE or nicedie "Seemingly failed to close $zone$zone_ext, cowardly quitting here."; close ZONE or nicedie "Seemingly failed to close $zone$zone_ext, cowardly quitting here.";
} }
sub del_ptr { sub del_ptr {
@ -137,6 +139,7 @@ sub del_ptr {
return 1 unless $rr->name eq $rec; return 1 unless $rr->name eq $rec;
return 0; return 0;
} }
$made_modifications = 1;
write_zone $rec,grep {&is_match(($_,$rec))} @_; write_zone $rec,grep {&is_match(($_,$rec))} @_;
} }
sub add_ptr { sub add_ptr {
@ -145,6 +148,7 @@ sub add_ptr {
my @z = get_zone_array $ip; my @z = get_zone_array $ip;
my $new_rr = Net::DNS::RR->new("$rec.$zone. 3600 IN PTR $fqdn"); my $new_rr = Net::DNS::RR->new("$rec.$zone. 3600 IN PTR $fqdn");
push @z,$new_rr; push @z,$new_rr;
$made_modifications = 1;
write_zone $zone,@z; write_zone $zone,@z;
} }
sub get_ptr { sub get_ptr {
@ -160,10 +164,10 @@ sub get_ptr {
} }
sub set_ptr { sub set_ptr {
my ($ip,$fqdn) = @_; my ($ip,$fqdn) = @_;
return add_ptr $ip,$fqdn unless does_record_exist $ip;
my ($record,$zone) = get_arpa $ip; my ($record,$zone) = get_arpa $ip;
my @z = get_zone_array $ip; my @z = get_zone_array $ip;
foreach(@z) { foreach(@z) {
$_->serial(generate_soa_serial $_->serial) if $_->type eq "SOA";
$_->ptrdname($fqdn) if $_->name eq "$record.$zone"; $_->ptrdname($fqdn) if $_->name eq "$record.$zone";
} }
$made_modifications = 1; $made_modifications = 1;
@ -176,10 +180,14 @@ sub sync_cpanel {
sub do_sync { sub do_sync {
my $ip = shift; my $ip = shift;
my ($rec,$zone) = get_arpa $ip; my ($rec,$zone) = get_arpa $ip;
my $res = '';
print "Syncing zone $zone... ";
for($net_type) { for($net_type) {
sync_cpanel $zone when /cpanel/; $res = sync_cpanel $zone when /cpanel/;
default { nicedie "Couldn't sync $zone: Don't have a known sync method for network type $net_type."; } default { nicedie "Couldn't sync $zone: Don't have a known sync method for network type $net_type."; }
} }
print (($res) ? "Synchronised" : "Failed");
print "!\n";
} }
#main #main
@ -204,15 +212,38 @@ nicedie "Invalid FQDN '$domain'!" if defined $domain and !validate_domain $domai
$domain =~ s/([a-zA-Z])$/$1./ if defined $domain; #Append final period if it doesn't exist $domain =~ s/([a-zA-Z])$/$1./ if defined $domain; #Append final period if it doesn't exist
#Main program flow #Main program flow
#Argument intelligence. Omitting this probably won't impact program flow much but it's important that the user know they're stupid.
nicedie "You seem to have specified both --no-sync and --force-sync. Please make your mind up." if $nosync and $fsync; nicedie "You seem to have specified both --no-sync and --force-sync. Please make your mind up." if $nosync and $fsync;
nicedie "You seem to have specified some combination of --reset, --remote-ptr and --force. Please make your mind up." if ($reset and $delptr) or (($reset or $delptr) and $force);
nicedie "You seem to have specified arguments that don't make sense together. Please make your mind up." if ($newzone and ($delptr or $reset or $force)) or ($verify and !defined $domain) or (defined $domain and ($newzone or $delptr or $reset));
#Simple check that the zone exists.
for(does_zone_exist $ip) { for(does_zone_exist $ip) {
my ($trec,$tz) = get_arpa $ip; my ($trec,$tz) = get_arpa $ip;
nicedie "Authoritative zone for IP $ip doesn't exist! Please create zone $tz or ensure you specified the correct subnet mask if this is an IPv6 address!" when -2; nicedie "Authoritative zone for IP $ip doesn't exist! Please create zone $tz or ensure you specified the correct subnet mask if this is an IPv6 address!" when -2;
nicedie "Zonefile $tz (supposedly authoritative for $ip) doesn't appear to be a valid BIND zone. Please check the zonefile and try again." when -1; nicedie "Zonefile $tz (supposedly authoritative for $ip) doesn't appear to be a valid BIND zone. Please check the zonefile and try again." when -1;
nicedie "Authoritative zone for IP $ip exists but we can't write to it. Please check the permissions on the zonefile for $tz." when 0; nicedie "Authoritative zone for IP $ip exists but we can't write to it. Please check the permissions on the zonefile for $tz." when 0;
} }
#if(!defined $domain and $reset) {
# set_ptr $ip,$def_rdns or nicedie "Failed to set rDNS for $ip to '$def_rdns'!"; if(!defined $domain and $reset) {
#} set_ptr $ip,$def_rdns or nicedie "Failed to set rDNS for $ip to '$def_rdns'!";
#do_sync $ip if (($made_modifications and !$nosync) or $fsync); print "rDNS set";
add_ptr $ip, $domain; print ((confirm_rdns $ip, $def_rdns) ? " and resolving" : " but not yet resolving (check manually with 'host $ip')") if $verify;
print ".\n";
} elsif(!defined $domain and $delptr) {
del_ptr $ip or nicedie "Failed to delete PTR record for $ip!";
nicedie "PTR record for IP $ip deleted.";
} elsif(!defined $domain and $newzone) {
nicedie "Sorry, but the zone population functionality isn't yet written.";
} elsif(!defined $domain) {
nicedie "No rDNS record for IP $ip exists." unless does_record_exist $ip;
nicedie "rDNS for IP $ip: ".get_ptr $ip;
}
if(defined $domain) {
nicedie "Forward DNS for $domain doesn't match $ip!" unless does_fqdn_match $ip or $force;
set_ptr $ip,$domain or nicedie "Failed to set rDNS for $ip to '$domain'!";
print "rDNS set";
print ((confirm_rdns $ip, $def_rdns) ? " and resolving" : " but not yet resolving (check manually with 'host $ip')") if $verify;
print ".\n";
}
do_sync $ip if (($made_modifications and !$nosync) or $fsync);