summaryrefslogtreecommitdiff
blob: 4a51e1565103a553a594747b13e3c38623465fac (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
# Copyright 1999-2011 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: $

EAPI=3

inherit eutils

DESCRIPTION="Minimalistic Murmur (Mumble server)"
HOMEPAGE="http://code.google.com/p/umurmur/"
SRC_URI="http://${PN}.googlecode.com/files/${P}.tar.gz"

LICENSE="BSD-3"
SLOT="0"
KEYWORDS="~amd64 ~x86"
IUSE="polarssl"

DEPEND="dev-libs/protobuf-c
	dev-libs/libconfig
	polarssl? ( >=net-libs/polarssl-1.1 )
	!polarssl? ( dev-libs/openssl )"

RDEPEND="${DEPEND}"

pkg_setup() {
	enewgroup umurmur || die
	enewuser umurmur "" "" "" umurmur || die
}

src_prepare() {
	epatch "${FILESDIR}/Fix-handling-of-long-cipherstrings-lists-with-OpenSSL.patch"
}

src_configure() {
	local myconf

	# build uses polarssl by default, but instead, make it use openssl unless
	# polarssl is desired.
	use !polarssl && myconf="${myconf} --with-ssl=openssl"

	econf ${myconf}
}

src_install() {
	emake DESTDIR="${D}" install || die "install failed"

	newinitd "${FILESDIR}/umurmurd.initd" umurmurd || die
	newconfd "${FILESDIR}/umurmurd.confd" umurmurd || die

	dodoc AUTHORS ChangeLog || die "dodoc failed"
	newdoc README.md README || die "newdoc failed"

	# Some permissions are adjusted as the config may contain a server
	# password, and /etc/umurmur will typically contain the cert and the key
	# used to sign it, which are read after priveleges are dropped.
	insinto /etc
	doins "${FILESDIR}/umurmur.conf" || die
	fperms 0640 /etc/umurmur.conf || die

	dodir /etc/umurmur || die
	fperms 0750 /etc/umurmur || die
	fowners root:umurmur /etc/umurmur || die
}

pkg_postinst() {
	elog "A configuration file has been installed at /etc/umurmur.conf - you may "
	elog "want to review it. See also http://code.google.com/p/umurmur/wiki/Configuring02x"

	if use polarssl ; then
		elog
		elog "Because you have enabled PolarSSL support, umurmurd will use a"
		elog "predefined test-certificate and key if none are configured, which"
		elog "is insecure. See http://code.google.com/p/umurmur/wiki/Installing02x#Installing_uMurmur_with_PolarSSL_support"
		elog "for more information on how to create your certificate and key"
	fi
}