1 |
commit: d83590e94a84d6f90c7a4b3bb0377b5734c892ca |
2 |
Author: Sergei Trofimovich <slyfox <AT> gentoo <DOT> org> |
3 |
AuthorDate: Sat Sep 22 17:29:31 2018 +0000 |
4 |
Commit: Sergei Trofimovich <slyfox <AT> gentoo <DOT> org> |
5 |
CommitDate: Sat Sep 22 17:29:31 2018 +0000 |
6 |
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d83590e9 |
7 |
|
8 |
net-im/openfire: set ownership at src_install() phase, bug #630914 |
9 |
|
10 |
As Michael explains in bug #630914 the code below is prone to |
11 |
chown-ing files not belonging to package: |
12 |
|
13 |
``` |
14 |
pkg_postinst() { |
15 |
... |
16 |
chown -R jabber:jabber "${ROOT}"/opt/openfire |
17 |
} |
18 |
``` |
19 |
|
20 |
Move chown to src_install() to contain the damage to builder. |
21 |
|
22 |
Reported-by: Michael Orlitzky |
23 |
Bug: https://bugs.gentoo.org/630914 |
24 |
Package-Manager: Portage-2.3.49, Repoman-2.3.10 |
25 |
|
26 |
net-im/openfire/openfire-4.2.3-r1.ebuild | 96 ++++++++++++++++++++++++++++++++ |
27 |
1 file changed, 96 insertions(+) |
28 |
|
29 |
diff --git a/net-im/openfire/openfire-4.2.3-r1.ebuild b/net-im/openfire/openfire-4.2.3-r1.ebuild |
30 |
new file mode 100644 |
31 |
index 00000000000..ea631de1f71 |
32 |
--- /dev/null |
33 |
+++ b/net-im/openfire/openfire-4.2.3-r1.ebuild |
34 |
@@ -0,0 +1,96 @@ |
35 |
+# Copyright 1999-2018 Gentoo Foundation |
36 |
+# Distributed under the terms of the GNU General Public License v2 |
37 |
+ |
38 |
+EAPI=6 |
39 |
+ |
40 |
+inherit eutils java-pkg-2 java-ant-2 systemd |
41 |
+ |
42 |
+MY_P=${PN}_src_${PV//./_} |
43 |
+DESCRIPTION="Openfire (formerly wildfire) real time collaboration (RTC) server" |
44 |
+HOMEPAGE="http://www.igniterealtime.org/projects/openfire/" |
45 |
+SRC_URI="http://www.igniterealtime.org/builds/openfire/${MY_P}.tar.gz" |
46 |
+ |
47 |
+LICENSE="GPL-2" |
48 |
+SLOT="0" |
49 |
+KEYWORDS="~amd64 ~x86" |
50 |
+IUSE="doc" |
51 |
+ |
52 |
+RDEPEND=">=virtual/jre-1.7" |
53 |
+DEPEND="net-im/jabber-base |
54 |
+ ~dev-java/ant-contrib-1.0_beta2 |
55 |
+ >=virtual/jdk-1.7" |
56 |
+ |
57 |
+S=${WORKDIR}/${PN}_src |
58 |
+ |
59 |
+pkg_setup() { |
60 |
+ java-pkg-2_pkg_setup |
61 |
+} |
62 |
+ |
63 |
+src_compile() { |
64 |
+ # Jikes doesn't support -source 1.5 |
65 |
+ java-pkg_filter-compiler jikes |
66 |
+ |
67 |
+ ANT_TASKS="ant-contrib" |
68 |
+ eant -f build/build.xml openfire plugins $(use_doc) |
69 |
+ |
70 |
+ # delete nativeAuth prebuilt libs: |
71 |
+ # uses outdated unmaintained libshaj, does not support amd64 |
72 |
+ rm -rfv target/openfire/resources/nativeAuth || die |
73 |
+} |
74 |
+ |
75 |
+src_install() { |
76 |
+ dodir /opt/openfire |
77 |
+ |
78 |
+ newinitd "${FILESDIR}"/openfire-initd openfire |
79 |
+ newconfd "${FILESDIR}"/openfire-confd openfire |
80 |
+ systemd_dounit "${FILESDIR}"/${PN}.service |
81 |
+ |
82 |
+ dodir /opt/openfire/conf |
83 |
+ insinto /opt/openfire/conf |
84 |
+ newins target/openfire/conf/openfire.xml openfire.xml.sample |
85 |
+ newins target/openfire/conf/security.xml security.xml.sample |
86 |
+ |
87 |
+ dodir /opt/openfire/logs |
88 |
+ keepdir /opt/openfire/logs |
89 |
+ |
90 |
+ dodir /opt/openfire/lib |
91 |
+ insinto /opt/openfire/lib |
92 |
+ doins target/openfire/lib/* |
93 |
+ |
94 |
+ dodir /opt/openfire/plugins |
95 |
+ insinto /opt/openfire/plugins |
96 |
+ doins -r target/openfire/plugins/* |
97 |
+ |
98 |
+ dodir /opt/openfire/resources |
99 |
+ insinto /opt/openfire/resources |
100 |
+ doins -r target/openfire/resources/* |
101 |
+ |
102 |
+ if use doc; then |
103 |
+ dohtml -r documentation/docs/* |
104 |
+ fi |
105 |
+ dodoc documentation/dist/* |
106 |
+ |
107 |
+ #Protect ssl key on upgrade |
108 |
+ dodir /etc/env.d/ |
109 |
+ echo 'CONFIG_PROTECT="/opt/openfire/resources/security/"' > "${D}"/etc/env.d/98openfire |
110 |
+ |
111 |
+ fowners -R jabber:jabber /opt/openfire |
112 |
+} |
113 |
+ |
114 |
+pkg_postinst() { |
115 |
+ local src |
116 |
+ local dst |
117 |
+ |
118 |
+ # http://community.igniterealtime.org/thread/52289 |
119 |
+ for dst in "${ROOT%/}"/opt/openfire/conf/{openfire,security}.xml |
120 |
+ do |
121 |
+ src="${dst}".sample |
122 |
+ if [[ -f "${dst}" ]]; then |
123 |
+ einfo "Leaving old '${dst}'" |
124 |
+ else |
125 |
+ einfo "Created default '${dst}'. Please edit." |
126 |
+ cp -v "${src}" "${dst}" || ewarn "cp '${dst}' failed" |
127 |
+ chmod -v 0600 "${dst}" || ewarn "chmod '${dst}' failed" |
128 |
+ fi |
129 |
+ done |
130 |
+} |