Gentoo Archives: gentoo-commits

From: Lars Wendler <polynomial-c@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: net-im/jabberd2/, net-im/jabberd2/files/
Date: Tue, 07 Feb 2017 10:42:13
Message-Id: 1486464122.c3f702918d97bbf6692f1fe07caa2969497b6d6e.polynomial-c@gentoo
1 commit: c3f702918d97bbf6692f1fe07caa2969497b6d6e
2 Author: Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
3 AuthorDate: Tue Feb 7 10:41:46 2017 +0000
4 Commit: Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
5 CommitDate: Tue Feb 7 10:42:02 2017 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c3f70291
7
8 net-im/jabberd2: Bump to version 2.5.0
9
10 Package-Manager: Portage-2.3.3, Repoman-2.3.1
11
12 net-im/jabberd2/Manifest | 1 +
13 .../files/jabberd2-2.3.4-optimization.patch | 4 +-
14 net-im/jabberd2/files/jabberd2-2.5.0.init | 91 ++++++++++
15 net-im/jabberd2/jabberd2-2.5.0.ebuild | 186 +++++++++++++++++++++
16 4 files changed, 280 insertions(+), 2 deletions(-)
17
18 diff --git a/net-im/jabberd2/Manifest b/net-im/jabberd2/Manifest
19 index 6d37dbc..030fdf1 100644
20 --- a/net-im/jabberd2/Manifest
21 +++ b/net-im/jabberd2/Manifest
22 @@ -1,2 +1,3 @@
23 DIST jabberd-2.3.3.tar.xz 1457340 SHA256 c6c2f34d0811e90c5c791143018bb5b07ecbe2ea5d8cc10140235d25815cb030 SHA512 c3c8d6829c3bc61555280d90edc1bef0228e4cec2684ba283373075883ef64bfa5e9118dad96d7a1193bb2afb6b2e7c78e24267e6feb6e7b191138bf8c79a7da WHIRLPOOL 0c590d79905ff95d2e18362065e0ba4e2341fdc95a61d3e157993d7d16976480b81f2f4b0479516538b1c5c0c9b496b446383da89c2e17539f8f9cb59db62463
24 DIST jabberd-2.3.4.tar.xz 1482736 SHA256 9a17fae72460dd4454814edb48a7a1af7071cf331dabc2b0b6029661a36bb671 SHA512 593c1a80de52447fa18e448627bdbf85605e8a406129808cd2081576c26d65df3315c5fc91b37d5e832e1a89b4083d873b2db1e65d6ad76fa5b9b4f125786b7f WHIRLPOOL 67a0e96a872a08975d981e1697fab5cf154b4cbea4c698d41d250c1314bc7303a3c15e871fc8b3c4f3769acd91773734ef61b880900132e435d17f9bde587b08
25 +DIST jabberd-2.5.0.tar.xz 1507916 SHA256 9ec4a8be6c01fe68cccee347e08aab34399205ecfe3557985debc368b86aeb8a SHA512 e1298f42a199bb31cea324f239368327a259eaaa3e4624eac5b6aca983f32467c47248c57e4621fd7f7eb64a3b86d760f5e9a57b4307174d820d20e77ae3229e WHIRLPOOL 4479955ba6f2511fda98660f51d1355532bf8f26c23a74b8aa892810d45c3ff3cdfbb7398d501c44048082e2d4dc50eb88dc135595ef0b35ba1c06c7dbe91d57
26
27 diff --git a/net-im/jabberd2/files/jabberd2-2.3.4-optimization.patch b/net-im/jabberd2/files/jabberd2-2.3.4-optimization.patch
28 index 4808162..d320b9d 100644
29 --- a/net-im/jabberd2/files/jabberd2-2.3.4-optimization.patch
30 +++ b/net-im/jabberd2/files/jabberd2-2.3.4-optimization.patch
31 @@ -3,8 +3,8 @@ bug.
32
33 See https://github.com/jabberd2/jabberd2/issues/34
34
35 ---- configure.ac
36 -+++ configure.ac
37 +--- a/configure.ac
38 ++++ b/configure.ac
39 @@ -23,13 +23,6 @@
40 LIBS="$LIBS $lt_cv_dlopen_libs"
41 fi
42
43 diff --git a/net-im/jabberd2/files/jabberd2-2.5.0.init b/net-im/jabberd2/files/jabberd2-2.5.0.init
44 new file mode 100644
45 index 00000000..c5e5710
46 --- /dev/null
47 +++ b/net-im/jabberd2/files/jabberd2-2.5.0.init
48 @@ -0,0 +1,91 @@
49 +#!/sbin/openrc-run
50 +# Copyright 1999-2017 Gentoo Foundation
51 +# Distributed under the terms of the GNU General Public License v2
52 +# $Id$
53 +
54 +extra_commands="reload"
55 +
56 +depend() {
57 + need net
58 + use mysql postgresql slapd
59 + provide jabber-server
60 +}
61 +
62 +stopJabberServices() {
63 + eindent
64 + for pidfile in /var/run/jabber/*.pid; do
65 + if [ -f "${pidfile}" ]; then
66 + service=$(basename ${pidfile} .pid)
67 + ebegin "Stopping ${service}"
68 + start-stop-daemon \
69 + --stop \
70 + --pidfile ${pidfile}
71 + eend $?
72 + fi
73 + done
74 + eoutdent
75 +}
76 +
77 +start_pre() {
78 + checkpath -d -o jabber /var/run/jabber
79 +}
80 +
81 +start() {
82 + einfo "Starting Jabber Server ..."
83 + local services executable cfgfile pidfile
84 + services=$(grep -v ^# /etc/jabber/jabberd.cfg | grep '..*' | awk '{print $1 ":" $2}')
85 + eindent
86 + for service in ${services}; do
87 +
88 + cfgfile=$(echo ${service} | cut -d ':' -f 2)
89 + service=$(echo ${service} | cut -d ':' -f 1)
90 + if [ ! -f "${cfgfile}" ]; then
91 + if [ -f "/etc/jabber/${service}.xml" ]; then
92 + cfgfile="/etc/jabber/${service}.xml"
93 + else
94 + eerror "Can't find: ${cfgfile} or default /etc/jabber/${service}.xml"
95 + stopJabberServices
96 + return 1
97 + fi
98 + fi
99 +
100 + executable="/usr/bin/$(echo ${service} | cut -d '.' -f 1)"
101 +
102 + if [ ! -f "${executable}" ]; then
103 + eerror "Can't find executable: ${executable}"
104 + stopJabberServices
105 + return 1
106 + fi
107 +
108 + ebegin "Starting ${service} (${cfgfile})"
109 + pidfile="$(grep -v ^# ${cfgfile} | grep '<pidfile>' | sed 's#<.\?pidfile>##g')"
110 + start-stop-daemon \
111 + --background \
112 + --start \
113 + --user jabber:jabber \
114 + --exec ${executable} \
115 + --pid ${pidfile} \
116 + -- -c ${cfgfile}
117 + eend $?
118 +
119 + done
120 + eoutdent
121 +}
122 +
123 +reload() {
124 + eindent
125 + for pidfile in /var/run/jabber/*.pid; do
126 + if [ -f "${pidfile}" ]; then
127 + service=$(basename ${pidfile} .pid)
128 + ebegin "Reloading ${service}"
129 + kill -HUP $(cat ${pidfile})
130 + eend $?
131 + fi
132 + done
133 + eoutdent
134 +}
135 +
136 +stop() {
137 + einfo "Stopping Jabber Server"
138 + stopJabberServices
139 +}
140
141 diff --git a/net-im/jabberd2/jabberd2-2.5.0.ebuild b/net-im/jabberd2/jabberd2-2.5.0.ebuild
142 new file mode 100644
143 index 00000000..0355816
144 --- /dev/null
145 +++ b/net-im/jabberd2/jabberd2-2.5.0.ebuild
146 @@ -0,0 +1,186 @@
147 +# Copyright 1999-2017 Gentoo Foundation
148 +# Distributed under the terms of the GNU General Public License v2
149 +# $Id$
150 +
151 +EAPI=6
152 +
153 +inherit autotools db-use eutils flag-o-matic pam
154 +
155 +DESCRIPTION="Open Source Jabber Server"
156 +HOMEPAGE="http://jabberd2.org"
157 +SRC_URI="https://github.com/jabberd2/jabberd2/releases/download/jabberd-${PV}/jabberd-${PV}.tar.xz"
158 +
159 +LICENSE="GPL-2"
160 +SLOT="0"
161 +KEYWORDS="~amd64 ~ppc ~sparc ~x86 ~x86-fbsd"
162 +IUSE="berkdb debug experimental ldap libressl memdebug mysql pam postgres sqlite ssl test websocket zlib"
163 +REQUIRED_USE="memdebug? ( debug )"
164 +
165 +# broken
166 +#RESTRICT="test"
167 +
168 +DEPEND="dev-libs/expat
169 + net-libs/udns
170 + net-dns/libidn
171 + virtual/gsasl
172 + berkdb? ( >=sys-libs/db-4.1.25:= )
173 + ldap? ( net-nds/openldap )
174 + mysql? (
175 + virtual/libmysqlclient:=
176 + virtual/mysql:=
177 + )
178 + pam? ( virtual/pam )
179 + postgres? ( dev-db/postgresql:= )
180 + ssl? (
181 + !libressl? ( >=dev-libs/openssl-1.0.1:0[-bindist] )
182 + libressl? ( dev-libs/libressl:= )
183 + )
184 + sqlite? ( dev-db/sqlite:3 )
185 + websocket? ( net-libs/http-parser:= )
186 + zlib? ( sys-libs/zlib )"
187 +RDEPEND="${DEPEND}
188 + >=net-im/jabber-base-0.01"
189 +DEPEND="${DEPEND}
190 + app-arch/xz-utils
191 + sys-devel/autoconf-archive
192 + virtual/pkgconfig
193 + test? ( dev-libs/check )"
194 +
195 +DOCS=( AUTHORS README )
196 +
197 +#PATCHES=(
198 +#)
199 +
200 +S="${WORKDIR}/jabberd-${PV}"
201 +
202 +pkg_pretend() {
203 + if is-flagq '-O[3s]' ; then
204 + ewarn "O3/Os compiler flags have been known to cause problems"
205 + ewarn "with old gcc version. Be aware that this could break"
206 + ewarn "port binding. Make sure to test this."
207 + ewarn "See https://github.com/jabberd2/jabberd2/issues/34"
208 + fi
209 +}
210 +
211 +src_prepare() {
212 + # Fix some default directory locations
213 + sed -i \
214 + -e 's,@localstatedir@/@package@/pid/,/var/run/@package@/,g' \
215 + -e 's,@localstatedir@/@package@/run/pbx,/var/run/@package@/pbx,g' \
216 + -e 's,@localstatedir@/@package@/log/,/var/log/@package@/,g' \
217 + -e 's,@localstatedir@/lib/jabberd2/fs,@localstatedir@/@package@/fs,g' \
218 + -e 's,@localstatedir@,/var/spool,g' \
219 + -e 's,@package@,jabber,g' \
220 + etc/{sm,router,c2s,s2s}.xml.dist.in || die "fixing default directory locations failed!"
221 +
222 + # If the package wasn't merged with sqlite then default to use berkdb
223 + use sqlite ||
224 + sed -i \
225 + -e 's,<\(module\|driver\)>sqlite<\/\1>,<\1>db</\1>,g' \
226 + etc/{c2s,sm}.xml.dist.in || die "setting berkdb as default failed!"
227 +
228 + # avoid file collision with x11-misc/screen-message wrt #453994
229 + sed -i \
230 + -e 's/@jabberd_router_bin@/jabberd2-router/' \
231 + -e 's/@jabberd_c2s_bin@/jabberd2-c2s/' \
232 + -e 's/@jabberd_s2s_bin@/jabberd2-s2s/' \
233 + -e 's/@jabberd_sm_bin@/jabberd2-sm/' \
234 + etc/jabberd*.in || die "fixing file collisions failed!"
235 +
236 + # rename pid files wrt #241472
237 + sed -i \
238 + -e '/pidfile/s/${id}\.pid/jabberd2-c2s\.pid/' \
239 + etc/c2s.xml.dist.in || die
240 + sed -i \
241 + -e '/pidfile/s/${id}\.pid/jabberd2-router\.pid/' \
242 + etc/router.xml.dist.in || die
243 + sed -i \
244 + -e '/pidfile/s/${id}\.pid/jabberd2-s2s\.pid/' \
245 + etc/s2s.xml.dist.in || die
246 + sed -i \
247 + -e '/pidfile/s/${id}\.pid/jabberd2-sm\.pid/' \
248 + etc/sm.xml.dist.in || die
249 +
250 + default
251 +
252 + eautoreconf
253 +}
254 +
255 +src_configure() {
256 + # --enable-pool-debug is currently broken
257 + myeconfargs=(
258 + --sysconfdir=/etc/jabber
259 + --enable-pipe
260 + --enable-anon
261 + --enable-fs
262 + $(usex debug "--enable-debug" "")
263 + $(usex memdebug "--enable-nad-debug" "")
264 + $(use_enable ssl)
265 + $(use_enable mysql)
266 + $(use_enable postgres pgsql)
267 + $(use_enable sqlite)
268 + $(use_enable berkdb db)
269 + $(use_enable ldap)
270 + $(use_enable pam)
271 + $(use_enable websocket)
272 + $(use_enable experimental)
273 + $(use_enable test tests)
274 + $(usex berkdb "--with-extra-include-path=$(db_includedir)" "")
275 + $(use_with zlib)
276 + )
277 + econf "${myeconfargs[@]}"
278 +}
279 +
280 +src_install() {
281 + local i
282 +
283 + default
284 + prune_libtool_files --modules
285 +
286 + keepdir /var/spool/jabber/{fs,db}
287 + fowners jabber:jabber /usr/bin/{jabberd,router,sm,c2s,s2s} \
288 + /var/spool/jabber/{fs,db}
289 + fperms 770 /var/spool/jabber/{fs,db}
290 + fperms 750 /usr/bin/{jabberd,router,sm,c2s,s2s}
291 +
292 + # avoid file collision with x11-misc/screen-message wrt #453994
293 + for i in router sm c2s s2s ; do
294 + einfo "renaming /usr/bin/${i} to /usr/bin/jabberd2-${i}"
295 + mv "${ED%/}"/usr/bin/${i} "${ED%/}"/usr/bin/jabberd2-${i} || die
296 + done
297 +
298 + newinitd "${FILESDIR}/${PN}-2.5.0.init" jabberd
299 + newpamd "${FILESDIR}/${PN}-2.3.1.pamd" jabberd
300 + insinto /etc/logrotate.d
301 + newins "${FILESDIR}/${PN}-2.3.2.logrotate" jabberd
302 +
303 + docompress -x /usr/share/doc/${PF}/tools
304 + docinto tools
305 + dodoc tools/db-setup{.mysql,.pgsql,.sqlite} \
306 + tools/{migrate-jd14dir-2-sqlite.pl,pipe-auth.pl}
307 +
308 + # remove useless upstart files wrt #498900
309 + rm -rf "${ED%/}"/usr/etc
310 +}
311 +
312 +pkg_postinst() {
313 + if use pam; then
314 + echo
315 + ewarn 'Jabberd-2 PAM authentication requires your unix usernames to'
316 + ewarn 'be in the form of "contactname@jabberdomain". This behavior'
317 + ewarn 'is likely to change in future versions of jabberd-2. It may'
318 + ewarn 'be advisable to avoid PAM authentication for the time being.'
319 + echo
320 + fi
321 +
322 + if use sqlite || use mysql || use postgres; then
323 + echo
324 + einfo "You will need to setup or update your database using the"
325 + einfo "scripts in /usr/share/doc/${PF}/tools/"
326 + echo
327 + fi
328 +
329 + ewarn 'If you are upgrading from <=jabberd2-2.2.17 then you might have'
330 + ewarn 'to update /etc/jabber/jabberd.cfg via etc-update because'
331 + ewarn 'the binaries have been renamed to avoid file collisions!'
332 +}