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 |
+} |