3 # $Id: bind.import,v 1.1 2002-05-23 13:00:08 ivan Exp $
5 #need to manually put header in /usr/local/etc/freeside/export.<datasrc./bind/<machine>/named.conf.HEADER
8 use vars qw( %d_part_svc );
9 use Term::Query qw(query);
10 #use BIND::Conf_Parser;
13 #use Net::SCP qw(iscp);
15 use FS::UID qw(adminsuidsetup datasrc);
16 use FS::Record qw(qsearch); #qsearchs);
19 use FS::domain_record;
23 my $user = shift or die &usage;
26 $FS::domain_record::noserial_hack = 1;
28 use vars qw($spooldir);
29 $spooldir = "/usr/local/etc/freeside/export.". datasrc. "/bind";
30 mkdir $spooldir unless -d $spooldir;
33 map { $_->svcpart, $_ } qsearch('part_svc',{'svcdb'=>'svc_domain'});
36 ( join "\n", map "$_: ".$d_part_svc{$_}->svc, sort keys %d_part_svc ),
38 use vars qw($domain_svcpart);
39 $^W=0; #Term::Query isn't -w-safe
41 query "Enter part number for domains: ", 'irk', [ keys %d_part_svc ];
45 Enter the location and name of your primary named.conf file, for example
46 "ns.isp.com:/var/named/named.conf"
48 my($named_conf)=&getvalue(":");
50 use vars qw($named_machine $prefix);
51 $named_machine = (split(/:/, $named_conf))[0];
52 $prefix = "$spooldir/$named_machine";
53 mkdir $prefix unless -d $prefix;
55 #iscp("root\@$named_conf","$prefix/named.conf.import");
56 scp("root\@$named_conf","$prefix/named.conf.import");
61 $^W=0; # Term::Query isn't -w-safe
62 my $return = query $prompt, '';
71 $FS::svc_domain::whois_hack=1;
74 $p->parse_file("$prefix/named.conf.import");
76 print "\nBIND import completed.\n";
81 die "Usage:\n\n svc_domain.import user\n";
88 use BIND::Conf_Parser;
89 use vars qw(@ISA $named_dir);
90 @ISA = qw(BIND::Conf_Parser);
93 my($self, $option, $argument) = @_;
94 return unless $option eq "directory";
95 $named_dir = $argument;
99 my($self, $name, $class, $type, $options) = @_;
100 return unless $class eq 'in';
101 return if grep { $name eq $_ }
102 ( qw( . localhost 127.in-addr.arpa 0.in-addr.arpa 255.in-addr.arpa ) );
104 my $domain = new FS::svc_domain( {
105 svcpart => $main::domain_svcpart,
109 my $error = $domain->insert;
110 die $error if $error;
112 if ( $type eq 'slave' ) {
115 #print Dumper($options);
118 foreach my $master ( @{ $options->{masters} } ) {
119 my $domain_record = new FS::domain_record( {
120 'svcnum' => $domain->svcnum,
123 'rectype' => '_mstr',
124 'recdata' => $master,
126 my $error = $domain_record->insert;
127 die $error if $error;
130 } elsif ( $type eq 'master' ) {
132 my $file = $options->{file};
135 my $basefile = basename($file);
136 my $sourcefile = $file;
137 $sourcefile = "$named_dir/$sourcefile" unless $file =~ /^\//;
138 use Net::SCP qw(iscp scp);
139 scp("root\@$main::named_machine:$sourcefile",
140 "$main::prefix/$basefile.import");
143 my $zone = DNS::ZoneParse->new("$main::prefix/$basefile.import");
145 my $dump = $zone->Dump;
148 #print "$name: ". Dumper($dump);
151 foreach my $rectype ( keys %$dump ) {
152 if ( $rectype =~ /^SOA$/i ) {
153 my $rec = $dump->{$rectype};
154 my $domain_record = new FS::domain_record( {
155 'svcnum' => $domain->svcnum,
156 'reczone' => $rec->{origin},
158 'rectype' => $rectype,
160 $rec->{primary}. ' '. $rec->{email}. ' ( '.
161 join(' ', map $rec->{$_},
162 qw( serial refresh retry expire minimumTTL ) ).
165 my $error = $domain_record->insert;
166 die $error if $error;
168 #die $dump->{$rectype};
169 foreach my $rec ( @{ $dump->{$rectype} } ) {
170 my $domain_record = new FS::domain_record( {
171 'svcnum' => $domain->svcnum,
172 'reczone' => $rec->{name},
173 'recaf' => $rec->{class},
174 'rectype' => $rectype,
175 'recdata' => ( $rectype =~ /^MX$/i
176 ? $rec->{priority}. ' '. $rec->{host}
179 my $error = $domain_record->insert;
180 die $error if $error;