Dynamic host configuration protocol software
Go to file
Jiri Popelka 7a016a6260 4.3.5b1
2016-09-12 17:24:05 +02:00
.gitignore 4.3.5b1 2016-09-12 17:24:05 +02:00
11-dhclient Fix 11-dhclient to export variables (#702735) 2011-05-09 14:32:51 +02:00
12-dhcpd dispatcher.d/12-dhcpd: use reset-failed command 2015-11-24 13:48:51 +01:00
56dhclient 56dhclient: ifcfg file was not sourced (#742482) 2011-09-30 15:59:33 +02:00
dhclient-script dhclient-script: hostname -> hostnamectl --transient 2015-11-23 13:07:31 +01:00
dhcp-64_bit_lease_parse.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-add_timeout_when_NULL.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-capability.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-client-request-release-bind-iface.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-CLOEXEC.patch 4.3.3b1 2015-08-10 12:09:24 +02:00
dhcp-default-requested-options.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-dhclient-decline-backoff.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-dhclient-options.patch [dhclient] rename -timeout option to --timeout 2016-08-03 13:29:33 +02:00
dhcp-dhclient-preinit6s.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-duid_uuid.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-duidv4.patch correctly set IB's hw->hlen (#1185075) 2015-02-26 10:16:23 +01:00
dhcp-errwarn-message.patch 4.3.0b1 2014-01-21 10:34:27 +01:00
dhcp-garbage-chars.patch 4.3.0rc1 2014-01-29 10:08:47 +01:00
dhcp-getifaddrs.patch 4.3.5b1 2016-09-12 17:24:05 +02:00
dhcp-gpxe-cid.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-honor-expired.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-improved-xid.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-interval.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-IPoIB-log-id.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-lpf-ib.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-manpages.patch 4.3.5b1 2016-09-12 17:24:05 +02:00
dhcp-no-subnet-error2info.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-option97-pxe-client-id.patch 4.3.5b1 2016-09-12 17:24:05 +02:00
dhcp-paths.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-PPP.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-release-by-ifup.patch 4.3.0a1: requires bind-9.9.5 2013-12-20 16:19:14 +01:00
dhcp-remove-bind.patch 4.3.5b1 2016-09-12 17:24:05 +02:00
dhcp-rfc3442-classless-static-routes.patch patch-fix 2016-05-02 16:01:30 +02:00
dhcp-sd_notify.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-sendDecline.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-sharedlib.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-stateless-DUID-LLT.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp-systemtap.patch 4.3.3b1 2015-08-10 12:09:24 +02:00
dhcp-unicast-bootp.patch 4.3.4 2016-05-02 15:19:54 +02:00
dhcp.spec 4.3.5b1 2016-09-12 17:24:05 +02:00
dhcpd6.service Use network-online.target instead of network.target (#1120656) 2014-07-22 19:00:42 +02:00
dhcpd.service Use network-online.target instead of network.target (#1120656) 2014-07-22 19:00:42 +02:00
dhcrelay.service Use network-online.target instead of network.target (#1120656) 2014-07-22 19:00:42 +02:00
README.dhclient.d Mentioning the bash script is needed in README.dhclient.d 2016-03-23 10:30:07 +01:00
sources 4.3.5b1 2016-09-12 17:24:05 +02:00
tap_all.stp SystemTap support: spec file change, some dummy probes, tapset, simple script 2011-09-21 15:40:15 +02:00

The /etc/dhcp/dhclient.d directory allows other packages and system
administrators to create application-specific option handlers for dhclient.

When dhclient is run, any option listed in the dhcp-options(5) man page can
be requested.  dhclient-script does not handle every option available
because doing so would make the script unmaintainable as the components
using those options might change over time.  The knowledge of how to handle
those options should be under the responsibility of the package maintainer
for that component (e.g., NTP options belong in a handler in the ntp
package).

To make maintenance easier, application specific DHCP options can be handled
by creating a bash script with two functions and placing it in /etc/dhcp/dhclient.d

The script must follow a specific form:

(1) The script must be named NAME.sh.  NAME can be anything, but it makes
    sense to name it for the service it handles.  e.g., ntp.sh

(2) The script must provide a NAME_config() function to read the options and
    do whatever it takes to put those options in place.

(3) The script must provide a NAME_restore() function to restore original
    configuration state when dhclient stops.

(4) The script must be 'chmod +x' or dhclient-script will ignore it.

The scripts execute in the same environment as dhclient-script.  That means
all of the functions and variables available to it are available to your
NAME.sh script.  Things of note:

    ${SAVEDIR} is where original configuration files are saved.  Save your
    original configuration files here before you take the DHCP provided
    values and generate new files.

    Variables set in /etc/sysconfig/network, /etc/sysconfig/networking/network,
    and /etc/sysconfig/network-scripts/ifcfg-$interface are available to
    you.

See the scripts in /etc/dhcp/dhclient.d for examples.

NOTE:  Do not use functions defined in /usr/sbin/dhclient-script.  Consider
dhclient-script a black box.  This script may change over time, so the
dhclient.d scripts should not be using functions defined in it.

-- 
David Cantrell <dcantrell@redhat.com>