NAME

Data::Checker::DNS - check data to see if it is valid in DNS

SYNOPSIS

use Data::Checker;
$obj = new Data::Checker;

$obj->check($data,"DNS",$check_opts);

DESCRIPTION

This module is meant to be used by the Data::Checker module.

One set of checks that is often done on sets of hosts is to check that they are defined in DNS. This module provides several DNS related checks that can be performed.

FUNCTIONS

check

This is the only function provided by this module, and it is intended to be used by the Data::Checker module.

CHECKS OPTIONS

The $check_opts hashref defines exactly what DNS checks to perform, and some options used by those checks. Known keys that specify the checks are:

qualified

If this keys is present, the hostname is tested to see if it is fully qualified or not.

This check does not actually do a DNS lookup. Instead, it looks at the hostname to see if is fully qualified or not.

If this is given, the host must be fully qualifed to pass (or unqualifed if the 'negate' option is given).

dns

If this key is present, the hostname is tested to see if it is in DNS. If the host is defined in DNS, it passes.

This is the default check done, and if $check_opts is not passed in, this check will be performed.

expected_ip, expected_domain, expected_hostname

If any of these keys are present, the information in DNS is tested to make sure that the values are as expected.

The expected value should be stored in the description passed to the check function (see Data::Checker for more information), or in the 'value' option in $check_opts.

If the description is a hashref and there are keys 'ip', 'domain', or 'hostname' respectively, the values are either a string or a listref of strings, and the value in DNS must match one of those strings.

Alternately, if the description does not exist or does not contain those keys, the 'value' option in $check_opts will be used.

If the 'negate' option is included, the values are restricted value which cannot be used in DNS.

The following keys can also be present to specify additional options:

nameservers

This is a whitespace separated list of nameservers to use.

KNOWN BUGS AND LIMITATIONS

None known.

SEE ALSO

Data::Checker

LICENSE

This script is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

AUTHOR

Sullivan Beck (sbeck@cpan.org)