removed Net::DDNS and updated master
This commit is contained in:
35
DDNS.pm
35
DDNS.pm
@ -2,7 +2,6 @@ package Martnet::DDNS;
|
|||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Net::DNS;
|
|
||||||
use File::Temp qw/tempfile/;
|
use File::Temp qw/tempfile/;
|
||||||
use Memoize;
|
use Memoize;
|
||||||
|
|
||||||
@ -12,13 +11,15 @@ our $VERSION = '0.4';
|
|||||||
|
|
||||||
# our $misterdns = '198.251.79.234';
|
# our $misterdns = '198.251.79.234';
|
||||||
our $misterdns = '5.78.68.64';
|
our $misterdns = '5.78.68.64';
|
||||||
|
our $defaultmaster = '5.78.68.64'; # could be v4 and v6 like '198.251.79.234;2607:f1c0:86e:b66f:6b86:babb:c367:b0dc'
|
||||||
|
our $keyfile = '/etc/bind/zone-management.key';
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my $me = shift;
|
my $me = shift;
|
||||||
my %opts = @_;
|
my %opts = @_;
|
||||||
|
|
||||||
return bless {
|
return bless {
|
||||||
'keyfile' => '/etc/bind/Knewmartnet.+165+36945.key',
|
'keyfile' => $keyfile,
|
||||||
%opts
|
%opts
|
||||||
}, $me;
|
}, $me;
|
||||||
}
|
}
|
||||||
@ -54,20 +55,26 @@ sub _lookupOrDie {
|
|||||||
_validateOrDie($dom);
|
_validateOrDie($dom);
|
||||||
my $fqdn = _fqdn($dom, $type);
|
my $fqdn = _fqdn($dom, $type);
|
||||||
|
|
||||||
my $res = Net::DNS::Resolver->new;
|
my $answer;
|
||||||
my $query = $res->query($fqdn, "TXT");
|
my $all = '';
|
||||||
|
my $fh;
|
||||||
if ($query) {
|
open($fh, "dig +short -t txt \@${misterdns} $fqdn |")
|
||||||
foreach my $rr (grep { $_->type eq 'TXT' } $query->answer) {
|
|| die "Can't open dig: $!";
|
||||||
# We found a record; that's all that I care about.
|
while (<$fh>) {
|
||||||
#print $rr->nsdname, "\n";
|
$all .= $_;
|
||||||
|
if ($_ =~ /^\"(.+)\"$/) {
|
||||||
|
$answer = $1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($answer) {
|
||||||
|
# We found a record; that's all I care about.
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else {
|
else {
|
||||||
die "query failed: ", $res->errorstring, "\n";
|
die "query failed: $all\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Unreached
|
||||||
die "Failed to find existing DNS record for $fqdn";
|
die "Failed to find existing DNS record for $fqdn";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -205,5 +212,11 @@ sub is_dnssec {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub default_master {
|
||||||
|
my ($this, $type) = @_;
|
||||||
|
|
||||||
|
# This could return different masters for different types
|
||||||
|
return $defaultmaster;
|
||||||
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|||||||
@ -3,8 +3,7 @@ use ExtUtils::MakeMaker;
|
|||||||
WriteMakefile(
|
WriteMakefile(
|
||||||
'NAME' => 'Martnet::DDNS',
|
'NAME' => 'Martnet::DDNS',
|
||||||
'VERSION_FROM' => 'DDNS.pm',
|
'VERSION_FROM' => 'DDNS.pm',
|
||||||
'PREREQ_PM' => { Net::DNS => 0.66,
|
'PREREQ_PM' => { File::Temp => 0.22,
|
||||||
File::Temp => 0.22,
|
|
||||||
Regexp::Common => 2013031301,
|
Regexp::Common => 2013031301,
|
||||||
},
|
},
|
||||||
'EXE_FILES' => [ 'bin/add-vhost',
|
'EXE_FILES' => [ 'bin/add-vhost',
|
||||||
|
|||||||
@ -7,7 +7,8 @@ use Regexp::Common qw/net/;
|
|||||||
|
|
||||||
my $host = shift || die "No zonename provided";
|
my $host = shift || die "No zonename provided";
|
||||||
my $master = shift;
|
my $master = shift;
|
||||||
$master ||= '198.251.79.234;2607:f1c0:86e:b66f:6b86:babb:c367:b0dc';
|
my $ddns = Martnet::DDNS->new();
|
||||||
|
$master ||= $ddns->default_master();
|
||||||
|
|
||||||
die "Zonename must end in a dot"
|
die "Zonename must end in a dot"
|
||||||
unless ($host =~ /^[a-zA-Z0-9\.\-\_]+\.$/);
|
unless ($host =~ /^[a-zA-Z0-9\.\-\_]+\.$/);
|
||||||
@ -16,5 +17,4 @@ my $regex = $RE{net}{IPv4} . '|' . $RE{net}{IPv6};
|
|||||||
die "Master must be an IPv4 or IPv6 address"
|
die "Master must be an IPv4 or IPv6 address"
|
||||||
unless ($master =~ /^$regex$/);
|
unless ($master =~ /^$regex$/);
|
||||||
|
|
||||||
my $ddns = Martnet::DDNS->new();
|
|
||||||
$ddns->add($host, $master, '_custom');
|
$ddns->add($host, $master, '_custom');
|
||||||
|
|||||||
@ -7,8 +7,8 @@ use Regexp::Common qw/net/;
|
|||||||
|
|
||||||
my $host = shift || die "No zonename provided";
|
my $host = shift || die "No zonename provided";
|
||||||
my $master = shift;
|
my $master = shift;
|
||||||
#$master ||= '198.251.79.234';
|
my $ddns = Martnet::DDNS->new();
|
||||||
$master ||= '198.251.79.234;2607:f1c0:86e:b66f:6b86:babb:c367:b0dc';
|
$master ||= $ddns->default_master();
|
||||||
|
|
||||||
|
|
||||||
die "Zonename must end in a dot"
|
die "Zonename must end in a dot"
|
||||||
@ -18,5 +18,4 @@ my $regex = $RE{net}{IPv4} . '|' . $RE{net}{IPv6};
|
|||||||
die "Master must be an IPv4 or IPv6 address"
|
die "Master must be an IPv4 or IPv6 address"
|
||||||
unless ($master =~ /^$regex$/);
|
unless ($master =~ /^$regex$/);
|
||||||
|
|
||||||
my $ddns = Martnet::DDNS->new();
|
|
||||||
$ddns->add($host, $master, '_dnssec');
|
$ddns->add($host, $master, '_dnssec');
|
||||||
|
|||||||
@ -6,8 +6,8 @@ use Martnet::DDNS;
|
|||||||
use Regexp::Common qw/net/;
|
use Regexp::Common qw/net/;
|
||||||
|
|
||||||
my $host = shift || die "No vhost provided";
|
my $host = shift || die "No vhost provided";
|
||||||
#my $master = shift || die "No master DNS IP provided";
|
my $ddns = Martnet::DDNS->new();
|
||||||
my $master ||= '198.251.79.234;2607:f1c0:86e:b66f:6b86:babb:c367:b0dc';
|
my $master ||= $ddns->default_master();
|
||||||
|
|
||||||
die "Hostname must end in a dot"
|
die "Hostname must end in a dot"
|
||||||
unless ($host =~ /^[a-zA-Z0-9\.\-\_]+\.$/);
|
unless ($host =~ /^[a-zA-Z0-9\.\-\_]+\.$/);
|
||||||
@ -16,5 +16,4 @@ my $regex = $RE{net}{IPv4} . '|' . $RE{net}{IPv6};
|
|||||||
die "Master must be an IPv4 or IPv6 address"
|
die "Master must be an IPv4 or IPv6 address"
|
||||||
unless ($master =~ /^$regex$/);
|
unless ($master =~ /^$regex$/);
|
||||||
|
|
||||||
my $ddns = Martnet::DDNS->new();
|
|
||||||
$ddns->add($host, $master, '_vhosts');
|
$ddns->add($host, $master, '_vhosts');
|
||||||
|
|||||||
Reference in New Issue
Block a user