/[pxelator]/lib/PXElator/dnsd.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /lib/PXElator/dnsd.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 122 by dpavlin, Mon Aug 3 08:57:59 2009 UTC revision 207 by dpavlin, Wed Aug 12 22:56:45 2009 UTC
# Line 4  use warnings; Line 4  use warnings;
4  use strict;  use strict;
5    
6  use Net::DNS::Nameserver;  use Net::DNS::Nameserver;
7    use Net::DNS::Resolver;
8  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
9    use CouchDB;
10    
11    use server;
12    our $debug = server::debug;
13    
14    my $res = Net::DNS::Resolver->new(
15    #       nameserver => [ '10.60.0.1' ],
16            recurse => 1,
17            debug => $debug,
18    );
19    
20    our $ptr_cache;
21    sub name_ip {
22            my ( $name, $ip ) = @_;
23            $ptr_cache->{ join('.', reverse split(/\./, $ip)) } = $name;
24            return $ip;
25    }
26    
27  sub reply_handler {  sub reply_handler {
28          my ($qname, $qclass, $qtype, $peerhost,$query,$conn) = @_;          my ($qname, $qclass, $qtype, $peerhost,$query,$conn) = @_;
29          my ($rcode, @ans, @auth, @add);          my ($rcode, @ans, @auth, @add);
30    
31          print "Received query from $peerhost to ". $conn->{"sockhost"}. "\n";          server->refresh;
32          $query->print;          $debug = server::debug;
33    
34            CouchDB::audit( 'request', {
35                    qname => $qname,
36                    qclass => $qclass,
37                    qtype => $qtype,
38                    peerhost =>  $peerhost,
39                    sockhost => $conn->{"sockhost"}
40            });
41    
42            $query->print if $debug;
43    
44                    my $local = $1     if $qname =~ m{^(.+)\.\Q$server::domain_name\E$};
45          if ($qtype eq "A" && $qname eq "foo.example.com" ) {             $local = $qname if $qname !~ m{\.};
46                  my ($ttl, $rdata) = (3600, "10.1.2.3");  
47                  push @ans, Net::DNS::RR->new("$qname $ttl $qclass $qtype $rdata");          my $ttl = 3600;
48    
49            if ( $local ) {
50                    warn "local[$local] $qname $qtype";
51                  $rcode = "NOERROR";                  $rcode = "NOERROR";
52          }elsif( $qname eq "foo.example.com" ) {                  my $rdata;
53                    if ( $qtype eq "A" && $local eq "server" ) {
54                            $rdata = name_ip( $local, $server::ip );
55                            CouchDB::audit('local', $rdata);
56                    } else {
57                            $rcode = "NXDOMAIN";
58                    }
59    
60                    push @ans, Net::DNS::RR->new("$qname $ttl $qclass $qtype $rdata") if $ttl;
61    
62            } elsif ( $qtype eq 'PTR' && $qname =~ m{^([0-9\.]*)\.in-addr\.arpa$} ) {
63                            if ( my $rdata = $ptr_cache->{$1} ) {
64                                    $rdata .= '.' . $server::domain_name;
65                                    push @ans, Net::DNS::RR->new("$qname $ttl $qclass $qtype $rdata");
66                                    CouchDB::audit('ptr', $rdata );
67                            } else {
68    warn "## ",dump( $ptr_cache );
69                                    $rcode = "NXDOMAIN";
70                            }
71            } elsif ( my $packet = $res->query( $qname, $qtype ) ) {
72    
73                    CouchDB::audit( 'upstream', $packet );
74                    $packet->print;
75                    push @ans, $_ foreach $packet->answer;
76                  $rcode = "NOERROR";                  $rcode = "NOERROR";
77    
78          }else{          } else {
79                   $rcode = "NXDOMAIN";                  # not found
80                    $rcode = "NXDOMAIN";
81          }          }
82    
83            warn "rcode: $rcode ",dump( @ans );
84    
85            CouchDB::audit('response', { rcode => $rcode, ans => [ @ans ], auth => [ @auth ], add => [ @add ] });
86    
87          # mark the answer as authoritive (by setting the 'aa' flag          # mark the answer as authoritive (by setting the 'aa' flag
88          return ($rcode, \@ans, \@auth, \@add, { aa => 1 });          return ($rcode, \@ans, \@auth, \@add, { aa => 1 });
89  }  }
# Line 33  sub start { Line 92  sub start {
92          my $ns = Net::DNS::Nameserver->new(          my $ns = Net::DNS::Nameserver->new(
93                  LocalPort    => 53,                  LocalPort    => 53,
94                  ReplyHandler => \&reply_handler,                  ReplyHandler => \&reply_handler,
95                  Verbose      => 1,                  Verbose      => $debug,
96          ) || die "couldn't create nameserver object\n";          ) || die "couldn't create nameserver object\n";
97    
98          warn dump( $ns );          CouchDB::audit('start', { listen => { port => 53, domain_name => $server::domain_name } });
99            warn "DNS $server::domain_name";
100    
101          $ns->main_loop;          $ns->main_loop;
102  }  }
103    
104  1;  1;

Legend:
Removed from v.122  
changed lines
  Added in v.207

  ViewVC Help
Powered by ViewVC 1.1.26