125 lines
4.3 KiB
Plaintext
125 lines
4.3 KiB
Plaintext
|
/** \page design Design
|
||
|
|
||
|
The following image shows the various modules of libdns and their
|
||
|
functionality.
|
||
|
|
||
|
\image html libdnsoverview.png
|
||
|
|
||
|
\section central_structures Central structures
|
||
|
|
||
|
- \ref ldns_pkt A DNS Packet, which can contain a query, answers, and additional information.
|
||
|
- \ref ldns_rr A Resource Record, which holds a bit of information about a specific domain name.
|
||
|
- \ref ldns_rdf An RDATA field, every Resource Record contains one or more RDATA fields, depending on the type of RR. These are the 'basic types' of DNS data.
|
||
|
- \ref ldns_rr_list A list of resource records
|
||
|
- \ref ldns_zone A representation of a DNS Zone.
|
||
|
|
||
|
The actual structure definitions are named \c ldns_struct_<name> which are all typedeffed to \c ldns_<name>
|
||
|
|
||
|
|
||
|
A DNS Resource record looks like this:
|
||
|
|
||
|
<pre>
|
||
|
nlnetlabs.nl. 600 IN MX 10 open.nlnetlabs.nl.
|
||
|
\ \ \ \ \ /
|
||
|
owner ttl class type \ rdf[] /
|
||
|
(rdf) (uint32_t) (rr_class) (rr_type)
|
||
|
10 := rdf[0]
|
||
|
open.nlnetlabs.nl. := rdf[1]
|
||
|
</pre>
|
||
|
|
||
|
* Owner:
|
||
|
The owner name is put in an \c ldns_rdf structure, which is a normal rdata field but always
|
||
|
has the type LDNS_RDF_TYPE_DNAME.
|
||
|
|
||
|
An \ref ldns_rdf structure has 3 members; the size, the type of rdata and a void *
|
||
|
pointer to the data. The data is always in uncompressed wireformat.
|
||
|
|
||
|
The RSH (rdata) is put in an array of rdf's (in this case 2).
|
||
|
|
||
|
The entire resource record is put in a RR structure, which has
|
||
|
the fields described above (under the RR):
|
||
|
- owner (nlnetlabs.nl.)
|
||
|
- ttl (600)
|
||
|
- class (LDNS_RR_CLASS_IN: 'IN')
|
||
|
- type (LDNS_RR_TYPE_MX: 'MX')
|
||
|
- rd_count (2)
|
||
|
- rdata_fields[rd_count]
|
||
|
- rdf[0] (10)
|
||
|
- rdf[1] (open.nlnetlabs.nl.)
|
||
|
|
||
|
* RR list structure:
|
||
|
An RR list structure is simply a structure with a counter
|
||
|
and an array of RR structures. Different kinds of RR's can
|
||
|
be grouped together this way.
|
||
|
|
||
|
* RRset structure:
|
||
|
An RRset structure is an RR list structure, but its accessor
|
||
|
function checks if the \c ldns_rr structures in there are:
|
||
|
- from the same type
|
||
|
- have the same TTL
|
||
|
- have the same ownername
|
||
|
|
||
|
This is the RFC definition of an RRset.
|
||
|
|
||
|
* pkt structure:
|
||
|
A pkt structure consists out of a header structure where
|
||
|
packet specific flags are kept, TC, RD, IP from the server which
|
||
|
sent the packet, etc.
|
||
|
Further more it is divided in 4 sections: question, authority, answer
|
||
|
and additional.
|
||
|
|
||
|
All four sections have the type RRlist that simply hold a list of RR's
|
||
|
|
||
|
|
||
|
\section wire_module Wire module and central structures Interface
|
||
|
|
||
|
As the WIRE module takes care of the compression/decompression
|
||
|
it needs a buffer which holds all the binary DNS data.
|
||
|
All functions will operate on such a buffer to extract specific
|
||
|
information which is then stored in RR structures.
|
||
|
|
||
|
|
||
|
\section resolver_module Resolver module and central structures Interface
|
||
|
|
||
|
The resolver module always returns a pkt structure. Either with
|
||
|
the answer or a SERVFAIL pkt.
|
||
|
|
||
|
The exact function-call parameters have not yet been
|
||
|
decided on.
|
||
|
|
||
|
Also the resolver module will need to access some of the
|
||
|
to_wire and from_wire function to creates ldn_pkt's from
|
||
|
the data it receives (arrow not drawn).
|
||
|
|
||
|
|
||
|
\section str_module str module and central structures Interface
|
||
|
|
||
|
Convert to and from strings. This module could be used
|
||
|
to read in a zone file (list of RRs) and convert the text strings to
|
||
|
the format used by ldns. Or the other way around.
|
||
|
|
||
|
|
||
|
\section net_module Net module and resolver module interface
|
||
|
|
||
|
The resolver module will get a packet and will mold it so that
|
||
|
it can be sent off to a nameserver.
|
||
|
It might need to interface with the wire module (arrow not drawn).
|
||
|
|
||
|
\section Net module and OS/libc interface
|
||
|
OS/network calls will be used here. The Net module is the only part of
|
||
|
the library where the underlying OS matters.
|
||
|
|
||
|
\section Client program ldns interface
|
||
|
Any client program will have access to
|
||
|
- Wire module
|
||
|
- Central structures
|
||
|
- Resolver module
|
||
|
- str module (arrow not drawn in the above figure)
|
||
|
|
||
|
\section dnssec_module DNSSEC module
|
||
|
The DNSSEC types are handled in the RR module, but the crypto
|
||
|
routines are contained in this module. This module will depend
|
||
|
on OpenSSL for the crypto routines.
|
||
|
|
||
|
*/
|