260 lines
7.3 KiB
Bash
260 lines
7.3 KiB
Bash
# Copyright 1999-2011 Gentoo Foundation
|
|
# Distributed under the terms of the GNU General Public License v2
|
|
# $Header: /var/cvsroot/gentoo-x86/net-misc/dhcp/dhcp-4.2.2.ebuild,v 1.3 2011/08/27 04:58:56 vapier Exp $
|
|
|
|
EAPI="2"
|
|
|
|
inherit eutils toolchain-funcs
|
|
|
|
MY_PV="${PV//_alpha/a}"
|
|
MY_PV="${MY_PV//_beta/b}"
|
|
MY_PV="${MY_PV//_rc/rc}"
|
|
MY_PV="${MY_PV//_p/-P}"
|
|
MY_P="${PN}-${MY_PV}"
|
|
DESCRIPTION="ISC Dynamic Host Configuration Protocol (DHCP) client/server"
|
|
HOMEPAGE="http://www.isc.org/products/DHCP"
|
|
SRC_URI="ftp://ftp.isc.org/isc/dhcp/${MY_P}.tar.gz"
|
|
|
|
LICENSE="as-is BSD"
|
|
SLOT="0"
|
|
KEYWORDS="~alpha ~amd64 ~arm ~hppa ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc x86 ~sparc-fbsd ~x86-fbsd"
|
|
IUSE="+client ipv6 kernel_linux ldap selinux +server ssl vim-syntax"
|
|
|
|
DEPEND="selinux? ( sec-policy/selinux-dhcp )
|
|
kernel_linux? ( sys-apps/net-tools )
|
|
vim-syntax? ( app-vim/dhcpd-syntax )
|
|
ldap? (
|
|
net-nds/openldap
|
|
ssl? ( dev-libs/openssl )
|
|
)"
|
|
RDEPEND="${DEPEND}"
|
|
|
|
S="${WORKDIR}/${MY_P}"
|
|
|
|
src_unpack() {
|
|
unpack ${A}
|
|
# handle local bind hell
|
|
cd "${S}"/bind
|
|
unpack ./bind.tar.gz
|
|
}
|
|
|
|
src_prepare() {
|
|
# Gentoo patches - these will probably never be accepted upstream
|
|
# Fix some permission issues
|
|
epatch "${FILESDIR}"/${PN}-3.0-fix-perms.patch
|
|
# Enable dhclient to equery NTP servers
|
|
epatch "${FILESDIR}"/${PN}-4.0-dhclient-ntp.patch
|
|
# resolvconf support in dhclient-script
|
|
epatch "${FILESDIR}"/${PN}-4.2.2-dhclient-resolvconf.patch
|
|
# Stop downing the interface on Linux as that breaks link daemons
|
|
# such as wpa_supplicant and netplug
|
|
epatch "${FILESDIR}"/${PN}-3.0.3-dhclient-no-down.patch
|
|
epatch "${FILESDIR}"/${PN}-4.2.0-errwarn-message.patch
|
|
# Enable dhclient to get extra configuration from stdin
|
|
epatch "${FILESDIR}"/${PN}-4.2.2-dhclient-stdin-conf.patch
|
|
epatch "${FILESDIR}"/${PN}-4.2.2-nogateway.patch #265531
|
|
|
|
# NetworkManager support patches
|
|
# If they fail to apply to future versions they will be dropped
|
|
# Add dbus support to dhclient
|
|
epatch "${FILESDIR}"/${PN}-3.0.3-dhclient-dbus.patch
|
|
|
|
# Brand the version with Gentoo
|
|
sed -i \
|
|
-e "/VERSION=/s:'$: Gentoo-${PR}':" \
|
|
configure || die
|
|
|
|
# Change the hook script locations of the scripts
|
|
sed -i \
|
|
-e 's,/etc/dhclient-exit-hooks,/etc/dhcp/dhclient-exit-hooks,g' \
|
|
-e 's,/etc/dhclient-enter-hooks,/etc/dhcp/dhclient-enter-hooks,g' \
|
|
client/scripts/* || die
|
|
|
|
# No need for the linux script to force bash, #158540.
|
|
sed -i -e 's,#!/bin/bash,#!/bin/sh,' client/scripts/linux || die
|
|
|
|
# Quiet the freebsd logger a little
|
|
sed -i -e '/LOGGER=/ s/-s -p user.notice //g' client/scripts/freebsd || die
|
|
|
|
# Remove these options from the sample config
|
|
sed -i \
|
|
-e "/\(script\|host-name\|domain-name\) / d" \
|
|
client/dhclient.conf || die
|
|
|
|
if use client && ! use server ; then
|
|
sed -i -r \
|
|
-e '/^SUBDIRS/s:\<(dhcpctl|relay|server)\>::g' \
|
|
Makefile.in || die
|
|
elif ! use client && use server ; then
|
|
sed -i -r \
|
|
-e '/^SUBDIRS/s:\<client\>::' \
|
|
Makefile.in || die
|
|
fi
|
|
|
|
# Only install different man pages if we don't have en
|
|
if [[ " ${LINGUAS} " != *" en "* ]]; then
|
|
# Install Japanese man pages
|
|
if [[ " ${LINGUAS} " == *" ja "* && -d doc/ja_JP.eucJP ]]; then
|
|
einfo "Installing Japanese documention"
|
|
cp doc/ja_JP.eucJP/dhclient* client
|
|
cp doc/ja_JP.eucJP/dhcp* common
|
|
fi
|
|
fi
|
|
# Now remove the non-english docs so there are no errors later
|
|
rm -rf doc/ja_JP.eucJP
|
|
|
|
# make the bind build work
|
|
binddir=${S}/bind
|
|
cd "${binddir}" || die
|
|
cat <<-EOF > bindvar.tmp
|
|
binddir=${binddir}
|
|
GMAKE=${MAKE:-gmake}
|
|
EOF
|
|
epatch "${FILESDIR}"/${PN}-4.2.2-bind-disable.patch
|
|
cd bind-*/
|
|
epatch "${FILESDIR}"/${PN}-4.2.2-bind-parallel-build.patch #380717
|
|
epatch "${FILESDIR}"/${PN}-4.2.2-bind-build-flags.patch
|
|
}
|
|
|
|
src_configure() {
|
|
# bind defaults to stupid `/usr/bin/ar`
|
|
tc-export AR BUILD_CC
|
|
export ac_cv_path_AR=${AR}
|
|
|
|
econf \
|
|
--enable-paranoia \
|
|
--sysconfdir=/etc/dhcp \
|
|
--with-cli-pid-file=/var/run/dhcp/dhclient.pid \
|
|
--with-cli-lease-file=/var/lib/dhcp/dhclient.leases \
|
|
--with-cli6-pid-file=/var/run/dhcp/dhclient6.pid \
|
|
--with-cli6-lease-file=/var/lib/dhcp/dhclient6.leases \
|
|
--with-srv-pid-file=/var/run/dhcp/dhcpd.pid \
|
|
--with-srv-lease-file=/var/lib/dhcp/dhcpd.leases \
|
|
--with-srv6-pid-file=/var/run/dhcp/dhcpd6.pid \
|
|
--with-srv6-lease-file=/var/lib/dhcp/dhcpd6.leases \
|
|
--with-relay-pid-file=/var/run/dhcp/dhcrelay.pid \
|
|
$(use_enable ipv6 dhcpv6) \
|
|
$(use_with ldap) \
|
|
$(use ldap && use_with ssl ldapcrypto || echo --without-ldapcrypto)
|
|
|
|
# configure local bind cruft
|
|
cd bind/bind-*/ || die
|
|
eval econf \
|
|
$(sed -n '/ [.].configure /{s:^[^-]*::;s:>.*::;p}' ../Makefile) \
|
|
--without-make-clean
|
|
}
|
|
|
|
src_compile() {
|
|
# build local bind cruft first
|
|
emake -C bind/bind-*/lib/export install || die
|
|
# then build standard dhcp code
|
|
emake || die
|
|
}
|
|
|
|
src_install() {
|
|
emake install DESTDIR="${D}" || die
|
|
|
|
dodoc README RELNOTES doc/{api+protocol,IANA-arp-parameters}
|
|
dohtml doc/References.html
|
|
|
|
if [[ -e client/dhclient ]] ; then
|
|
# move the client to /
|
|
dodir /sbin
|
|
mv "${D}"/usr/sbin/dhclient "${D}"/sbin/ || die
|
|
|
|
exeinto /sbin
|
|
if use kernel_linux ; then
|
|
newexe "${S}"/client/scripts/linux dhclient-script || die
|
|
else
|
|
newexe "${S}"/client/scripts/freebsd dhclient-script || die
|
|
fi
|
|
|
|
insinto /etc/dhcp
|
|
doins client/dhclient.conf || die
|
|
|
|
keepdir /var/lib/dhclient
|
|
fi
|
|
|
|
if [[ -e server/dhcpd ]] ; then
|
|
if use ldap ; then
|
|
insinto /etc/openldap/schema
|
|
doins contrib/ldap/dhcp.* || die
|
|
dosbin contrib/ldap/dhcpd-conf-to-ldap || die
|
|
fi
|
|
|
|
newinitd "${FILESDIR}"/dhcpd.init3 dhcpd
|
|
newinitd "${FILESDIR}"/dhcrelay.init2 dhcrelay
|
|
newconfd "${FILESDIR}"/dhcpd.conf dhcpd
|
|
newconfd "${FILESDIR}"/dhcrelay.conf dhcrelay
|
|
|
|
insinto /etc/dhcp
|
|
doins server/dhcpd.conf || die
|
|
|
|
keepdir /var/{lib,run}/dhcp
|
|
fi
|
|
}
|
|
|
|
pkg_preinst() {
|
|
enewgroup dhcp
|
|
enewuser dhcp -1 -1 /var/lib/dhcp dhcp
|
|
|
|
# Keep the user files over the sample ones
|
|
local f
|
|
for f in dhclient dhcpd ; do
|
|
f="/etc/dhcp/${f}.conf"
|
|
if [ -e "${ROOT}"${f} ] ; then
|
|
cp -p "${ROOT}"${f} "${D}"${f}
|
|
fi
|
|
done
|
|
}
|
|
|
|
pkg_postinst() {
|
|
chown -R dhcp:dhcp "${ROOT}"/var/{lib,run}/dhcp
|
|
|
|
if [[ -e "${ROOT}"/etc/init.d/dhcp ]] ; then
|
|
ewarn
|
|
ewarn "WARNING: The dhcp init script has been renamed to dhcpd"
|
|
ewarn "/etc/init.d/dhcp and /etc/conf.d/dhcp need to be removed and"
|
|
ewarn "and dhcp should be removed from the default runlevel"
|
|
ewarn
|
|
fi
|
|
|
|
einfo "You can edit /etc/conf.d/dhcpd to customize dhcp settings."
|
|
einfo
|
|
einfo "If you would like to run dhcpd in a chroot, simply configure the"
|
|
einfo "DHCPD_CHROOT directory in /etc/conf.d/dhcpd and then run:"
|
|
einfo " emerge --config =${PF}"
|
|
}
|
|
|
|
pkg_config() {
|
|
local CHROOT="$(
|
|
sed -n -e 's/^[[:blank:]]\?DHCPD_CHROOT="*\([^#"]\+\)"*/\1/p' \
|
|
"${ROOT}"/etc/conf.d/dhcpd
|
|
)"
|
|
|
|
if [[ -z ${CHROOT} ]]; then
|
|
eerror "CHROOT not defined in /etc/conf.d/dhcpd"
|
|
return 1
|
|
fi
|
|
|
|
CHROOT="${ROOT}/${CHROOT}"
|
|
|
|
if [[ -d ${CHROOT} ]] ; then
|
|
ewarn "${CHROOT} already exists - aborting"
|
|
return 0
|
|
fi
|
|
|
|
ebegin "Setting up the chroot directory"
|
|
mkdir -m 0755 -p "${CHROOT}/"{dev,etc,var/lib,var/run/dhcp}
|
|
cp /etc/{localtime,resolv.conf} "${CHROOT}"/etc
|
|
cp -R /etc/dhcp "${CHROOT}"/etc
|
|
cp -R /var/lib/dhcp "${CHROOT}"/var/lib
|
|
ln -s ../../var/lib/dhcp "${CHROOT}"/etc/dhcp/lib
|
|
chown -R dhcp:dhcp "${CHROOT}"/var/{lib,run}/dhcp
|
|
eend 0
|
|
|
|
local logger="$(best_version virtual/logger)"
|
|
einfo "To enable logging from the dhcpd server, configure your"
|
|
einfo "logger (${logger}) to listen on ${CHROOT}/dev/log"
|
|
}
|