NAME

CfgTie::TieNamed -- A tool to help configure the name daemon (BIND DNS server)

SYNOPSIS

This is a PERL module to help make it easy to configure the DNS name server

DESCRIPTION

This is a tie hash to the NAMED configuration files. You use it as follows:

tie %named, 'CfgTie::TieNamed','/path/to/named.boot';
$named = CfgTie::TieNamed->new('/path/to/named.boot');

These will set up a hash (named) to the named configuration files. It will used the specified named.boot file.

tie %named, 'CfgTie::TieNamed';
$named = CfgTie::TieNamed->new();

These will set up a hash (named) to the named configuration files. The files will be automatically determined from the system startup scripts.

Examples

Lets say you would like to name a bunch of machines (like modems) with a base name and a number. The number part needs to be the same as the same as the last number in the IP address. You know these go in a domain like, "wikstrom.pilec.rm.net" which is a zone for your name server:

tie %DNS, 'CfgTie::TieNamed';
my $Tbl = $DNS->{'primary'}->{'wikstrom.pilec.rm.net'};
my $N=10; #Ten modems;
my $prefix="usr2-port";
my $ip_start=11;
for (my $i = 0; $i < $N; $i++)
{
   #Insert the address record in the table
   $Tbl->{$prefix.$i}->{'A'} = "127.221.19.".($i+$ip_start);
}

#Finally make sure that the reverse name space is up to date
(tied %DNS)->RevXRef('wikstrom.pilec.rm.net','19.221.127.in-addr.arpa');

Even the address to name mapping will be kept up to date.

The basic structure of the named configuration table

bogusns

A list of name server addresses to ignore.

cache

See named(8) for a description

check-names
directory

This specifies the working directory of the named server, and is used in determining the location of the associated files.

forwarders

A list of other servers' addresses on the site that can be used for recursive look up.

limit

Controls operational parameters of the named server. See below.

options

The list of options the named server should adhere to.

primary

This maps to a an associative array of name spaces we are primary for. See below for more details on this is handled.

secondary

This maps to a an associative array of name spaces we are secondary for.

sortlist

See named(8) for a description

xfrnets

The list of networks which are allowed to request zone transfers. If not present, all hosts on all networks are.

Others may be set as well, but they are for backwards compatibility and should be changed to the more appopriate form. See named(8) for more information.

Extra methods for the configuration table

These are various methods you can use. Of course, you will need an object reference you can use for the remaining methods. Note that if you tied the variable, you will want to use code sorta like: my $Obj = tied %CfgTie::TieNamed;

RevSpaces Is the list of the reverses addresses spaces that the server is primary for (except loopback)

FwdSpaces Is the list of name spaces the server is primary for (except the loopback and reverse name spaces)

RevXRef($fwd,$rev) This will check that reverse look up is up to date with the primary look up. It will add reverse entries as appropriate (if there is one missing, or the value is correct). It will not change a reverse entry if there are multiple names with the same address entry. rev is optional, but this method will return (with a 0) if it is not specified and there is more than one reverse name space. fwd is optional, but this method will return (with a 0) if it is not specified and there is more than one primary name space. Returns the number of entries changed or added.

Note: This also derives any other methods from the CfgTie::Cfgfile module (CfgTie::Cfgfile).

The basic structure of a primary name space table

The $named->{primary} entry refers to a associative arrays. The keys are the domain names that are to be server. ie,

my %mydom = $name->{primary}->{'mydomain.com'};

These associations in turn refer to a table of names and their respective attributes. The keys to this table are the machine names.

The values associated keys are hash references to domain name records. This in turn refers to another (confused yet?) associative array. The keys of this table are the DNS attribute names. The values associated with the key are list references, usually a set of possible values for the given attribute and name pair. The most common ones are:

A

This is a list reference to all of the physical addresses the given machine name has.

NS

This is a list reference to all of the servers that can serve as domain name servers.

CNAME

This is a list reference to all of the real names the given machine name has.

SOA

Has a list reference with the following structure HOSTDATAFROM MAILADDR SERIAL REFRESH RETRY EXPIRE MinTTL The Serial number is automatically updated for each table that is changed. The format is guessed (from various date formats include YYYYMMDD, YYYYDDD, and others), and properly incremented or set.

PTR

This is a list reference to the real name of a given machines address.

TXT

Each element of this list refers to a string describing the domain or name.

WKS
HINFO

Extra methods table

DblLinks This looks for entries with both a A and a CNAME entry. Keep controls whether to keep the A or the CNAME entry; the default is to keep the A entry (and delete the CNAME entry). Returns a count of all the records that were modified.

Note: This also derives any other methods from the CfgTie::Cfgfile module (CfgTie::Cfgfile).

See Also

CfgTie::Cfgfile, CfgTie::TieAliases, CfgTie::TieGeneric, CfgTie::TieGroup, CfgTie::TieHost, CfgTie::TieNet, CfgTie::TiePh, CfgTie::TieProto, CfgTie::TieRCService, CfgTie::TieServ, CfgTie::TieShadow, CfgTie::TieUser

Cavaets

Much of the information is cached and the file is updated at the end. The named process will sent the SIGHUP signal to restart and reload the configuration files.

The reverse name file can not be automatically created... Only modified.

The SOA records in the named configuration files are not easy to change.

Changing the file name or directory currently does not move the files in the file system

Author

Randall Maas (randym@acm.org)