blob: 2eaae13bc97ab88c7cda20b4f6f8b7c7d8c1f9e3 (
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
# Copyright 1999-2021 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
inherit autotools systemd readme.gentoo-r1
DESCRIPTION="Minimalistic Murmur (Mumble server)"
HOMEPAGE="https://github.com/umurmur/umurmur"
if [[ "${PV}" == *9999 ]] ; then
inherit git-r3
EGIT_REPO_URI="https://github.com/umurmur/umurmur.git"
else
SRC_URI="https://github.com/${PN}/${PN}/archive/${PV/_}.tar.gz -> ${P}.tar.gz"
KEYWORDS="~amd64 ~arm ~x86"
fi
LICENSE="BSD"
SLOT="0"
IUSE="gnutls libressl mbedtls shm"
# ssl-provider precendence: gnutls, mbedtls, libressl
# and openssl if none specified
DEPEND=">=dev-libs/protobuf-c-1.0.0_rc2:=
dev-libs/libconfig:=
gnutls? (
dev-libs/nettle:=
>=net-libs/gnutls-3.0.0:=
)
!gnutls? (
mbedtls? ( net-libs/mbedtls:= )
!mbedtls? (
libressl? ( dev-libs/libressl:0= )
!libressl? ( dev-libs/openssl:0= )
)
)
"
RDEPEND="${DEPEND}
acct-group/murmur
acct-user/murmur
"
DOC_CONTENTS="
A configuration file has been installed at /etc/umurmur/umurmur.conf - you
may want to review it. See also\n
https://github.com/umurmur/umurmur/wiki/Configuration "
S="${WORKDIR}/${P/_}"
get_ssl_impl() {
local ssl_provider=()
use gnutls && ssl_provider+=( gnutls )
use mbedtls && ssl_provider+=( mbedtls )
use libressl && ssl_provider+=( libressl )
if ! use gnutls && ! use mbedtls && ! use libressl ; then
ssl_provider+=( openssl )
fi
echo ${ssl_provider[@]}
}
pkg_pretend() {
local ssl_provider=( $(get_ssl_impl) )
if [[ ${#ssl_provider[@]} -gt 1 ]] ; then
ewarn "More than one ssl provider selected (${ssl_provider[@]})"
ewarn "defaulting to ${ssl_provider[0]}."
fi
}
src_prepare() {
default
eautoreconf
}
src_configure() {
local ssl_provider=( $(sed 's@libressl@openssl@' <<< $(get_ssl_impl)) )
local myeconfargs=(
--with-ssl="${ssl_provider[@]}"
$(use_enable shm shmapi)
)
econf "${myeconfargs[@]}"
}
src_install() {
local confdir
emake DESTDIR="${D}" install
newinitd "${FILESDIR}"/umurmurd.initd umurmurd
newconfd "${FILESDIR}"/umurmurd.confd umurmurd
systemd_dounit "${FILESDIR}"/umurmurd.service
dodoc AUTHORS ChangeLog
newdoc README.md README
confdir="/etc/umurmur"
insinto "${confdir}"
doins "${FILESDIR}"/umurmur.conf
# 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.
fperms 0750 "${confdir}"
fowners -R root:murmur "${confdir}"
fperms 0640 "${confdir}"/umurmur.conf
readme.gentoo_create_doc
}
pkg_postinst() {
readme.gentoo_print_elog
}
|