pureslaves now work too
This commit is contained in:
71
DDNS.pm
71
DDNS.pm
@ -5,7 +5,7 @@ use warnings;
|
|||||||
use Net::DNS;
|
use Net::DNS;
|
||||||
use File::Temp qw/tempfile/;
|
use File::Temp qw/tempfile/;
|
||||||
|
|
||||||
our $VERSION = '0.1';
|
our $VERSION = '0.2';
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my $me = shift;
|
my $me = shift;
|
||||||
@ -17,10 +17,20 @@ sub new {
|
|||||||
}, $me;
|
}, $me;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub _fqdn {
|
sub _validateTypeOrDie {
|
||||||
my ($dom) = @_;
|
my ($t) = @_;
|
||||||
|
|
||||||
return $dom . "_vhosts.private.invalid.";
|
die "Invalid type"
|
||||||
|
unless ($t =~ /^_(vhosts|hostedservers|pureslave|custom)$/);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub _fqdn {
|
||||||
|
my ($dom, $type) = @_;
|
||||||
|
$type ||= '_vhosts';
|
||||||
|
|
||||||
|
_validateTypeOrDie($type);
|
||||||
|
|
||||||
|
return $dom . "$type.private.invalid.";
|
||||||
}
|
}
|
||||||
|
|
||||||
sub _validateOrDie {
|
sub _validateOrDie {
|
||||||
@ -36,7 +46,7 @@ sub _lookupOrDie {
|
|||||||
my ($dom) = @_;
|
my ($dom) = @_;
|
||||||
|
|
||||||
_validateOrDie($dom);
|
_validateOrDie($dom);
|
||||||
my $fqdn = _fqdn($dom);
|
my $fqdn = _fqdn($dom, '_vhosts');
|
||||||
|
|
||||||
my $res = Net::DNS::Resolver->new;
|
my $res = Net::DNS::Resolver->new;
|
||||||
my $query = $res->query($fqdn, "TXT");
|
my $query = $res->query($fqdn, "TXT");
|
||||||
@ -77,29 +87,11 @@ sub __docmd {
|
|||||||
unlink $filename;
|
unlink $filename;
|
||||||
}
|
}
|
||||||
|
|
||||||
# Add a new vhost domain by adding a DDNS record that the slaves will notice.
|
|
||||||
sub addvhost {
|
|
||||||
my ($this, $dom, $master) = @_;
|
|
||||||
|
|
||||||
_validateOrDie($dom);
|
sub _gethosts {
|
||||||
my $fqdn = _fqdn($dom);
|
my ($this, $type) = @_;
|
||||||
|
|
||||||
$this->__docmd("update add $fqdn 60 TXT $master");
|
_validateTypeOrDie($type);
|
||||||
$this->cleanup();
|
|
||||||
}
|
|
||||||
|
|
||||||
sub delvhost {
|
|
||||||
my ($this, $dom) = @_;
|
|
||||||
|
|
||||||
_lookupOrDie($dom);
|
|
||||||
my $fqdn = _fqdn($dom);
|
|
||||||
|
|
||||||
$this->__docmd("update delete $fqdn TXT");
|
|
||||||
$this->cleanup();
|
|
||||||
}
|
|
||||||
|
|
||||||
sub getvhosts {
|
|
||||||
my ($this) = @_;
|
|
||||||
|
|
||||||
my $fh;
|
my $fh;
|
||||||
open($fh, "dig -t AXFR \@127.0.0.1 private.invalid. |")
|
open($fh, "dig -t AXFR \@127.0.0.1 private.invalid. |")
|
||||||
@ -108,7 +100,7 @@ sub getvhosts {
|
|||||||
my @vh;
|
my @vh;
|
||||||
|
|
||||||
while (<$fh>) {
|
while (<$fh>) {
|
||||||
if (/^(\S+)._vhosts.private.invalid.\s+\d+\s+IN\s+TXT\s+\"(.+)\"$/) {
|
if (/^(\S+).$type.private.invalid.\s+\d+\s+IN\s+TXT\s+\"(.+)\"$/) {
|
||||||
push (@vh, { zone => $1,
|
push (@vh, { zone => $1,
|
||||||
master => $2 });
|
master => $2 });
|
||||||
}
|
}
|
||||||
@ -117,6 +109,31 @@ sub getvhosts {
|
|||||||
return @vh;
|
return @vh;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub add {
|
||||||
|
my ($this, $dom, $master, $type) = @_;
|
||||||
|
_validateOrDie($dom);
|
||||||
|
my $fqdn = _fqdn($dom, $type);
|
||||||
|
|
||||||
|
$this->__docmd("update add $fqdn 60 TXT $master");
|
||||||
|
$this->cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
sub del {
|
||||||
|
my ($this, $dom, $type) = @_;
|
||||||
|
|
||||||
|
_lookupOrDie($dom);
|
||||||
|
my $fqdn = _fqdn($dom, $type);
|
||||||
|
|
||||||
|
$this->__docmd("update delete $fqdn TXT");
|
||||||
|
$this->cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
sub get {
|
||||||
|
my ($this, $type) = @_;
|
||||||
|
|
||||||
|
return $this->_gethosts($type);
|
||||||
|
}
|
||||||
|
|
||||||
sub cleanup {
|
sub cleanup {
|
||||||
my ($this) = @_;
|
my ($this) = @_;
|
||||||
# Merge the .jnl file in with the domain file
|
# Merge the .jnl file in with the domain file
|
||||||
|
|||||||
@ -11,6 +11,9 @@ WriteMakefile(
|
|||||||
'bin/del-vhost',
|
'bin/del-vhost',
|
||||||
'bin/list-vhosts',
|
'bin/list-vhosts',
|
||||||
'bin/sync-master-vhosts',
|
'bin/sync-master-vhosts',
|
||||||
|
'bin/add-slave',
|
||||||
|
'bin/del-slave',
|
||||||
|
'bin/list-slaves',
|
||||||
],
|
],
|
||||||
'AUTHOR' => 'Jorj Bauer <jorj@jorj.org>',
|
'AUTHOR' => 'Jorj Bauer <jorj@jorj.org>',
|
||||||
);
|
);
|
||||||
|
|||||||
19
bin/add-slave
Executable file
19
bin/add-slave
Executable file
@ -0,0 +1,19 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use Martnet::DDNS;
|
||||||
|
use Regexp::Common qw/net/;
|
||||||
|
|
||||||
|
my $host = shift || die "No zonename provided";
|
||||||
|
my $master = shift || die "No master DNS IP provided";
|
||||||
|
|
||||||
|
die "Zonename must end in a dot"
|
||||||
|
unless ($host =~ /^[a-zA-Z0-9\.\-\_]+\.$/);
|
||||||
|
|
||||||
|
my $regex = $RE{net}{IPv4} . '|' . $RE{net}{IPv6};
|
||||||
|
die "Master must be an IPv4 or IPv6 address"
|
||||||
|
unless ($master =~ /^$regex$/);
|
||||||
|
|
||||||
|
my $ddns = Martnet::DDNS->new();
|
||||||
|
$ddns->add($host, $master, '_pureslave');
|
||||||
@ -17,4 +17,4 @@ die "Master must be an IPv4 or IPv6 address"
|
|||||||
unless ($master =~ /^$regex$/);
|
unless ($master =~ /^$regex$/);
|
||||||
|
|
||||||
my $ddns = Martnet::DDNS->new();
|
my $ddns = Martnet::DDNS->new();
|
||||||
$ddns->addvhost($host, $master);
|
$ddns->add($host, $master, '_vhosts');
|
||||||
|
|||||||
14
bin/del-slave
Executable file
14
bin/del-slave
Executable file
@ -0,0 +1,14 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use Martnet::DDNS;
|
||||||
|
use Regexp::Common qw/net/;
|
||||||
|
|
||||||
|
my $host = shift || die "No zonename provided";
|
||||||
|
|
||||||
|
die "Zonename must end in a dot"
|
||||||
|
unless ($host =~ /^[a-zA-Z0-9\-\_\.]+\.$/);
|
||||||
|
|
||||||
|
my $ddns = Martnet::DDNS->new();
|
||||||
|
$ddns->del($host, '_pureslave');
|
||||||
@ -11,4 +11,4 @@ die "Hostname must end in a dot"
|
|||||||
unless ($host =~ /^[a-zA-Z0-9\-\_\.]+\.$/);
|
unless ($host =~ /^[a-zA-Z0-9\-\_\.]+\.$/);
|
||||||
|
|
||||||
my $ddns = Martnet::DDNS->new();
|
my $ddns = Martnet::DDNS->new();
|
||||||
$ddns->delvhost($host);
|
$ddns->del($host, '_vhosts');
|
||||||
|
|||||||
12
bin/list-slaves
Executable file
12
bin/list-slaves
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use Martnet::DDNS;
|
||||||
|
|
||||||
|
my $ddns = Martnet::DDNS->new();
|
||||||
|
|
||||||
|
my @vh = $ddns->get('_pureslave');
|
||||||
|
foreach my $i (sort {$a->{zone} cmp $b->{zone}} @vh) {
|
||||||
|
print $i->{zone}, ". master: ", $i->{master},"\n";
|
||||||
|
}
|
||||||
@ -6,7 +6,7 @@ use Martnet::DDNS;
|
|||||||
|
|
||||||
my $ddns = Martnet::DDNS->new();
|
my $ddns = Martnet::DDNS->new();
|
||||||
|
|
||||||
my @vh = $ddns->getvhosts();
|
my @vh = $ddns->get('_vhosts');
|
||||||
foreach my $i (sort {$a->{zone} cmp $b->{zone}} @vh) {
|
foreach my $i (sort {$a->{zone} cmp $b->{zone}} @vh) {
|
||||||
print $i->{zone}, ". master: ", $i->{master},"\n";
|
print $i->{zone}, ". master: ", $i->{master},"\n";
|
||||||
}
|
}
|
||||||
|
|||||||
@ -7,7 +7,7 @@ use File::Temp qw/tempfile/;
|
|||||||
|
|
||||||
my $ddns = Martnet::DDNS->new();
|
my $ddns = Martnet::DDNS->new();
|
||||||
|
|
||||||
my @vh = $ddns->getvhosts();
|
my @vh = $ddns->get('_vhosts');
|
||||||
|
|
||||||
# For each virtual host, generate a vhost zone file if there isn't one
|
# For each virtual host, generate a vhost zone file if there isn't one
|
||||||
my $changecount = 0;
|
my $changecount = 0;
|
||||||
|
|||||||
@ -1,2 +1,2 @@
|
|||||||
MAILTO=jorj@jorj.org
|
MAILTO=jorj@jorj.org
|
||||||
* * * * * bind /usr/local/bin/sync-master-vhosts
|
* * * * * root /usr/local/bin/sync-master-vhosts
|
||||||
|
|||||||
Reference in New Issue
Block a user