NAME
Net::ISC::DHCPd - Interacts with ISC DHCPd
VERSION
0.1709
SYNOPSIS
my $dhcpd = Net::ISC::DHCPd->new(
config => { file => "path/to/config" },
leases => { file => "path/to/leases" },
omapi => { key => "some key" },
);
$dhcpd->config->parse;
See the tests bundled to this distribution for more examples.
DESCRIPTION
This namespace contains three semi-separate projects, which this module binds together: dhcpd.conf, dhcpd.leases and omapi. It is written with Moose which provides classes and roles to represents things like a host, a lease or any other thing.
The distribution as a whole is targeted an audience who configure and/or analyze the Internet Systems Consortium DHCP Server. If you are not familiar with the server, check out the man pages.
ATTRIBUTES
config
This attribute holds a read-only Net::ISC::DHCPd::Config object. It can be set from the constructor, using either an object or a hash-ref. The hash-ref will then be passed on to the constructor.
leases
This attribute holds a read-only Net::ISC::DHCPd::Leases object. It can be set from the constructor, using either an object or a hash-ref. The hash-ref will then be passed on to the constructor.
omapi
This attribute holds a read-only Net::ISC::DHCPd::OMAPI object. It can be set from the constructor, using either an object or a hash-ref. The hash-ref will then be passed on to the constructor.
binary
This attribute holds a Path::Class::File object to the dhcpd binary. It is read-only and the default is "dhcpd3".
errstr
Holds the last know error as a plain string. This only applies to OMAPI.
METHODS
parse
$config->parse;
This parses the config file or the leases file.
generate
print $config->generate;
This generates a copy of the config file in plaintext.
test
$bool = $self->test("config");
$bool = $self->test("leases");
Will test either the config or leases file. It returns a boolean value which indicates if it is valid or not: True means it is valid, while false means it is invalid. Check "errstr" on failure - it will contain a descriptive string from either this module, $!
or the exit value (integer stored as a string).
SEE ALSO
- Net::DHCP::Info
-
Net::DHCP::Info
an older dhcpd.leases and dhcpd.conf parser, also written by Jan Henning Thorsen. It has many limitations that these modules address. - kea.isc.org
-
kea.isc.org
a replacement DHCP server from ISC that is high-performance and supports an API and on-line configuration directly.
BUGS
Please report any bugs or feature requests to bug-net-isc-dhcpd at rt.cpan.org
, or through the web interface at https://github.com/jhthorsen/net-isc-dhcpd/issues. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
COPYRIGHT & LICENSE
Copyright 2007 Jan Henning Thorsen, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
AUTHOR
Jan Henning Thorsen, <jhthorsen at cpan.org>
MAINTAINER
Robert Drake, <rdrake at cpan.org>
CONTRIBUTORS
Nito Martinez
Alexey Illarionov
Patrick
napetrov
zoffixznet
Bossi