blob: 3f4df4582b79cb45a89a6e99042fe8ddf0676621 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
# Copyright 1999-2012 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-dns/ddclient/ddclient-3.8.0.ebuild,v 1.3 2012/06/14 02:02:30 zmedico Exp $
inherit eutils user
DESCRIPTION="Perl updater client for dynamic DNS services"
HOMEPAGE="http://ddclient.sourceforge.net/"
SRC_URI="mirror://sourceforge/${PN}/${P}.tar.gz"
LICENSE="GPL-2"
SLOT="0"
KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86 ~x86-fbsd"
IUSE="ssl"
RDEPEND=">=dev-lang/perl-5.1
ssl? ( dev-perl/IO-Socket-SSL )"
pkg_setup() {
enewgroup ${PN}
enewuser ${PN} -1 -1 -1 ${PN}
}
src_unpack() {
unpack ${A}
cd "${S}"
epatch "${FILESDIR}/${PN}-reasonable-security.patch"
einfo "Applying version string fix"
if ! sed -i "s/3\.7\.1/$PV/" "$PN"; then
eerror "Failed to update ddclient's internal version string"
eerror 'ddclient 3.7.2 will erroneously report a version of 3.7.1'
fi
# Remove pid line, because it is specified in /etc/conf.d/ddclient
einfo "Applying PID setup"
if ! sed -i "/^pid=*/d" "sample-etc_${PN}.conf"; then
eerror "Failed to remove pid from /etc/$PN/$PN.conf"
eerror "Please set the PID in /etc/conf.d/$PN, not /etc/$PN/$PN.conf"
fi
if ! use ssl; then
einfo "Disabling ssl per your useflags"
sed -i "/^ssl=*/d" "sample-etc_${PN}.conf" ||
eerror "Failed to remove ssl from /etc/$PN/$PN.conf"
fi
}
src_install() {
dosbin ${PN} || die "dosbin failed"
dodoc README* Change* COPYRIGHT sample*
newinitd "${FILESDIR}"/${PN}.initd ${PN}
newconfd "${FILESDIR}"/${PN}.confd ${PN}
keepdir /var/{cache,run}/${PN}
# Filename of sample conf - use live filename if available
local sample=${PN}.conf
[[ -e "/etc/${PN}/${sample}" ]] && sample="${sample}.sample"
insinto /etc/${PN}
insopts -m 0640 -o root -g ${PN}
newins sample-etc_${PN}.conf "${sample}" || die "newins conf failed"
}
pkg_postinst() {
# ensure the directories are owned by the user:group for this pkg
chown ${PN}:${PN} /var/{cache,run}/${PN}
use ssl && return
ewarn
ewarn "$PN will not have support for ssl, which means your dynamic DNS account"
ewarn "information -- including your password -- will be sent over the Internet in the"
ewarn "clear. To secure your information, add 'ssl' to your USEflags,"
ewarn "emerge -N ddclient, and add 'ssl=yes' to /etc/$PN/$PN.conf"
ewarn
}
|