Gentoo Archives: gentoo-commits

From: Thomas Deutschmann <whissi@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: net-firewall/shorewall/
Date: Mon, 29 Oct 2018 14:54:22
Message-Id: 1540824843.9684940802ac82dbbb0eff5ca1b9e1b83b815ff4.whissi@gentoo
1 commit: 9684940802ac82dbbb0eff5ca1b9e1b83b815ff4
2 Author: Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
3 AuthorDate: Mon Oct 29 13:30:48 2018 +0000
4 Commit: Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
5 CommitDate: Mon Oct 29 14:54:03 2018 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=96849408
7
8 net-firewall/shorewall: bump to v5.2.1.1
9
10 Package-Manager: Portage-2.3.51, Repoman-2.3.11
11 Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>
12
13 net-firewall/shorewall/Manifest | 7 +
14 net-firewall/shorewall/shorewall-5.2.1.1.ebuild | 479 ++++++++++++++++++++++++
15 2 files changed, 486 insertions(+)
16
17 diff --git a/net-firewall/shorewall/Manifest b/net-firewall/shorewall/Manifest
18 index 65b3e1bc59e..8a3f2870510 100644
19 --- a/net-firewall/shorewall/Manifest
20 +++ b/net-firewall/shorewall/Manifest
21 @@ -1,14 +1,21 @@
22 DIST shorewall-5.2.0.5.tar.bz2 539666 BLAKE2B df4f8680ee29a773f584a1210b40a7047be1a590490a01617b26b71840e488f569ebcf268ba2f6199fb10671925356c4e187a5219ed7784672f6d14b2e90f580 SHA512 8299e0f40ad96c09eceb9460c6088e694e50b7a1b81a16395426466c666eb21dc23236c1ee6cc6047c05ad4a4ba43aac33fc7cb05f5784bf27ac81e5fa4e9059
23 +DIST shorewall-5.2.1.1.tar.bz2 552739 BLAKE2B bfbfdb3320eb884b965f3c7b8d5af61a78bb625a10ad2bc493a5c8a191d676d933855335209a41f893ccb2edb644cf510930da936227fad9fb667793dce88e91 SHA512 59e1b4bb09114162911f0cb42d67df0d82c5a4410322ceb972506705c10cf903cb482123a00181399da99513c857d382771de36ec11433ff7bd9d57a343c48dc
24 DIST shorewall-5.2.1.tar.bz2 550552 BLAKE2B c7b77912f644b3ae1a15a366018bc57da72d23342ec9db4ba282c8bc993f4964b3ce6d783448e2e36a6370fd223e1d14f1b27e9cadfa47024a1dda8109419c7f SHA512 2c408196a142a314f72ea4adb4193fa5cf30300529c41661e157e7b69f2d8448a0c25bcd177f25d6f993494b26068edf48cc0fc8e6a526380726baa33a8e11c8
25 DIST shorewall-core-5.2.0.5.tar.bz2 76567 BLAKE2B 078520ef3166d689d559f1c08ae417a2bf5c7fdc3618a26f72b244fa14679634752dffaeebafbd84609e33ec7f1856b701abb297077797abcb14d3264a3bfd25 SHA512 640c854a7484e886cd603742d16682456e02c0054c3d6d5f2188bf30e235ac975fc1ce50af500cf4fb99253a1d13c2408cc72aff54f14aa738e1e80b8d07066a
26 +DIST shorewall-core-5.2.1.1.tar.bz2 78022 BLAKE2B dfa53a4558ec819feee25116021e410ac65dfad20d3d9384e3a233d47e7e443957149d025166d094397fb2c01b8be7694db8c06e927776250b5edafa97e5d287 SHA512 0c12d5deb4a93fb174a7c97459f2863149eec52ab778c30523c23cbdfbeb94d890442a0eb8ad9869158a967f2daac59a9d7194734e35e69982889d93d984b58b
27 DIST shorewall-core-5.2.1.tar.bz2 76562 BLAKE2B 6129e90f9cfca9b36221320eb917f3299dd151d366e2b98d546519330cd5c95511d4a1e7b1a4ea2de046aed2d2a72367f8e3039ad288de89178e161cb16eb5a0 SHA512 4ea3fdec0c4ffb57a7e63334aed3479819079936575928b01399a3c2a8515a4ecf1eb19f1e193849480e6ac84f4c7de9e4c84699765684fb2299bf1b5276a3a8
28 DIST shorewall-docs-html-5.2.0.5.tar.bz2 4295236 BLAKE2B 8cef99b3535551e1d4ecdf0d3d1c2b3434c0b91c793f0857bc3f22f0020d80cd49b038c7c4f5d15fe23af14869f1736a69b01978403fe94bc5dac261bd2f5e4d SHA512 5fa3ab52580e8f090ab0be9b1796bef65a41d1a9dc5c9501e3daeba22bad7b28b5306aba5b383c654eed5f7d727a7744812034eeb1ad051633a80b2892096c24
29 +DIST shorewall-docs-html-5.2.1.1.tar.bz2 4303275 BLAKE2B d2a9c980f0486671103653a6944e12f03e282bd859a9c06558d6dbfdf9fd6a7c72993355ab61138c94317d36228cbbb55903c9d17547ecdc18af57e989a5ef7b SHA512 c9eef71fdc53a97a523a580c5df0c7773f7dc6fc8abfbfe7a2fbc607be6d0e6377f47886001a87a37260118edb298880abda06e3ac4581d8551b3934791332fc
30 DIST shorewall-docs-html-5.2.1.tar.bz2 4302517 BLAKE2B a38659f9740da36efe3a2bf844b9686a18bb47476388580d02462aec0715afb1d09d20ffb2ee708550f7288fb7bb36ae8e5f23d902bd126bb2a5c496866e49dd SHA512 c67c621c1fea599c5e1987a7847bed187d8d0571e1b6d42c9fc351022de04b47e4f57030f919b85e8c9fef51829e0b04cbbc14e29a0df6f084c765219d46591c
31 DIST shorewall-init-5.2.0.5.tar.bz2 30881 BLAKE2B 92617f17553b6df514cbfc72e86597e9859baa641782848763923ff4c650915cd7fb97f0c71b41d525d6a9d5ebbf10e9918d6a8d682c9c4654de3ba40b54c0ce SHA512 0367ad7468d5a9c0c70d31fdd66c05e54cf747dd45dc1bf2e128935c65af8c2508f033ed2945185059214dd81f5a8fb3f122323fd2bb79d2d642997741167371
32 +DIST shorewall-init-5.2.1.1.tar.bz2 33215 BLAKE2B 3b151f60e368cd4237a8549d6de14ec4ed896c2c838f680a59aa12492c46bfb48accfa1a5bc98877663523861040af4995628e75f693c9fa5433483ef0fc6161 SHA512 21cdccc01b60df48e7e1204102c0b371d7e32fb1f897310e31a6cff128ebf5ed5efe3903bc487aa41ee093c23eb87e59764b78903ee5c6eba03552a1dcccc634
33 DIST shorewall-init-5.2.1.tar.bz2 31705 BLAKE2B 7f6a6b5266d63e3b0fab99a49f342e8172a20f50471fdcebe07a6c62dc36fcf4d96a041870df815aa5ecf2c421b5d7cb1408c0f54f520295611d54a876150294 SHA512 caba4eebcc576bf261327cb7304aedcaaea7325a34e444b4dd9ce60cd545b479271ea9b7049743ac1499485695d7d0f2a37b127a895cb3d200e6dfb41a21fe17
34 DIST shorewall-lite-5.2.0.5.tar.bz2 36651 BLAKE2B 192ecda8b04d0330f0a7bced6136f2723d201cd7c30af80b59bfa81f49614d10c900cf5856296ad854287f3c925e5f78f144698674ec7b8d91065072db4ca53e SHA512 b95154f7614eeedde1fc087750372cadd0c0a9618986741e035a9d83c06d2534feb78edaf6a97e2a45788015e6706f8dac3714ca3b22bd068e792458a3f5af40
35 +DIST shorewall-lite-5.2.1.1.tar.bz2 39020 BLAKE2B 40697930bb2251062a126a4bd86cd8379d32d9543f32d67208106205b35d3ae9cb9a67e48a48451053ae90138ffcda6cbe5dd5ce7c25bda6eab340dd4680bec8 SHA512 c10ee8ec81817fe8fc35caac253a89fb58be105fa1fb1c692d269f6916537007d555daeba4e5445568a6a6972dfc6db3e21f5637844c6a5e51e91b2a4795724d
36 DIST shorewall-lite-5.2.1.tar.bz2 37527 BLAKE2B 5a50d66366b5c4c456fd4291d1413923162cfe24f989df00be5f613089d96402430ec6c6780c78ee5e398cd931c964e8d164efefb4d1531cb870ba65040809be SHA512 111f68c2d59b58e7d344e55b293d78fe2013771be9f8399bea88d9699905f3683931668fad23e7efea1fcae9d3c6381bd9f2073c3f208e81cec958ab19b2510e
37 DIST shorewall6-5.2.0.5.tar.bz2 185740 BLAKE2B 846a3fc44a9c0a838cf75671ca34e78dd9758eeee0690d994a34615467b241f0c854e3bb9b818bcfd5e96664ab03e14a7c69affc946dffd1357ad744da41f8d5 SHA512 6875074ed8ee5bce40253a6e2633c422d7c2c1bf860a072236d6197cfe949e455b511a1792d822a8f2351254e99880236267ce70fc1150ca68e87f962b6cc265
38 +DIST shorewall6-5.2.1.1.tar.bz2 191039 BLAKE2B 4d40d30d4d6ad6a9aacf4acc4da6a4b31546a07969f12fde0d568f75e31ca587a31a830f386092ec0061df8cbff4032402c834e374076097fedb5de18127071b SHA512 0eb342a89f875527242be5e91c64a2debb7e2d159f5edc7f53a86c504e4e782f5635dd4e52b573526d1528d4aa4944384f52f68dc9a7c25513c3e5b2a7922b8c
39 DIST shorewall6-5.2.1.tar.bz2 188322 BLAKE2B 5814433b11001f1e00ce3b124b5ec4ca6b1909ec00f966cb5fc93c34207325853249964492eb03f1f3c73cfc9c1b42def9578e507395395dd067f236475215b5 SHA512 b5dd5c4bf014c24a8a8bb4dc38b45dc92749182091b572340e1aef12d0aaeeb1dc436716b449cc1de34c74c6e4d590cc8cbe6b73aa3c614e8c9c37d7fa7a00a6
40 DIST shorewall6-lite-5.2.0.5.tar.bz2 36370 BLAKE2B 212cee0313c3bbf08c8d22893c5b62125d0362eb66218dc954bc05d0e082fdb4dab209a05948300394943dcd97f698c1e02310ec54cc88fb72bd24d4383776f7 SHA512 18bcbaf3bd56aaadb8d42610d4868278f42299e5a022ac5732f730b34ed7d97f7cd013f1c9374f0a6afc809250288490d94d2b4e02e4bf5edf2542bff99150e4
41 +DIST shorewall6-lite-5.2.1.1.tar.bz2 38766 BLAKE2B 3a60a877516676a85f5d5d645ce3140c92438c7bb44abb5d8b8e188611bc14a0f3611e977a26526e6408439dd29eb00584217230e20e94ead9f5cbab73a980b3 SHA512 3df814352027ef9f16df030c7187eaa4d7b984cbb23e123eaa19a123a85e276a730b510ff7a76cafba80978474ed5bcb57a4b569332396780e14f7aa7d0d8669
42 DIST shorewall6-lite-5.2.1.tar.bz2 37244 BLAKE2B 4fcd5a1b65b15a7c4214b079677f6ee3604d1a718fe6a4710d42085434af64bcef9db57135b0c6b0e6678dba6272a4341330e47b8a6917c759e450091c7d1b5a SHA512 ca807bf0d59db09439d80725e6eeafb7795346bd030fe8598dcccc4fc93a57819715c33c73035c1819a9eba93efe69e058be1377fcd9adf135a0a08f6ff3e481
43
44 diff --git a/net-firewall/shorewall/shorewall-5.2.1.1.ebuild b/net-firewall/shorewall/shorewall-5.2.1.1.ebuild
45 new file mode 100644
46 index 00000000000..1666426f5c3
47 --- /dev/null
48 +++ b/net-firewall/shorewall/shorewall-5.2.1.1.ebuild
49 @@ -0,0 +1,479 @@
50 +# Copyright 1999-2018 Gentoo Authors
51 +# Distributed under the terms of the GNU General Public License v2
52 +
53 +EAPI="6"
54 +
55 +inherit linux-info prefix systemd versionator
56 +
57 +DESCRIPTION='A high-level tool for configuring Netfilter'
58 +HOMEPAGE="http://www.shorewall.net/"
59 +LICENSE="GPL-2"
60 +SLOT="0"
61 +IUSE="doc +init +ipv4 ipv6 lite4 lite6 selinux"
62 +
63 +MY_PV=${PV/_rc/-RC}
64 +MY_PV=${MY_PV/_beta/-Beta}
65 +MY_P=${PN}-${MY_PV}
66 +
67 +MY_MAJOR_RELEASE_NUMBER=$(get_version_component_range 1-2)
68 +MY_MAJORMINOR_RELEASE_NUMBER=$(get_version_component_range 1-3)
69 +
70 +# shorewall
71 +MY_PN_IPV4=Shorewall
72 +MY_P_IPV4=${MY_PN_IPV4/#S/s}-${MY_PV}
73 +
74 +# shorewall6
75 +MY_PN_IPV6=Shorewall6
76 +MY_P_IPV6=${MY_PN_IPV6/#S/s}-${MY_PV}
77 +
78 +# shorewall-lite
79 +MY_PN_LITE4=Shorewall-lite
80 +MY_P_LITE4=${MY_PN_LITE4/#S/s}-${MY_PV}
81 +
82 +# shorewall6-lite
83 +MY_PN_LITE6=Shorewall6-lite
84 +MY_P_LITE6=${MY_PN_LITE6/#S/s}-${MY_PV}
85 +
86 +# shorewall-init
87 +MY_PN_INIT=Shorewall-init
88 +MY_P_INIT=${MY_PN_INIT/#S/s}-${MY_PV}
89 +
90 +# shorewall-core
91 +MY_PN_CORE=Shorewall-core
92 +MY_P_CORE=${MY_PN_CORE/#S/s}-${MY_PV}
93 +
94 +# shorewall-docs-html
95 +MY_PN_DOCS=Shorewall-docs-html
96 +MY_P_DOCS=${MY_PN_DOCS/#S/s}-${MY_PV}
97 +
98 +# Upstream URL schema:
99 +# Beta: $MIRROR/pub/shorewall/development/4.6/shorewall-4.6.4-Beta2/shorewall-4.6.4-Beta2.tar.bz2
100 +# RC: $MIRROR/pub/shorewall/development/4.6/shorewall-4.6.4-RC1/shorewall-4.6.4-RC1.tar.bz2
101 +# Release: $MIRROR/pub/shorewall/4.6/shorewall-4.6.3/shorewall-4.6.3.3.tar.bz2
102 +
103 +MY_URL_PREFIX=
104 +MY_URL_SUFFIX=
105 +if [[ ${MY_PV} = *-Beta* ]] || [[ ${MY_PV} = *-RC* ]]; then
106 + MY_URL_PREFIX='development/'
107 +
108 + _tmp_last_index=$(($(get_last_version_component_index ${MY_PV})+1))
109 + _tmp_suffix=$(get_version_component_range ${_tmp_last_index} ${MY_PV})
110 + if [[ ${_tmp_suffix} = *Beta* ]] || [[ ${_tmp_suffix} = *RC* ]]; then
111 + MY_URL_SUFFIX="-${_tmp_suffix}"
112 + fi
113 +
114 + # Cleaning up temporary variables
115 + unset _tmp_last_index
116 + unset _tmp_suffix
117 +else
118 + KEYWORDS="~alpha ~amd64 ~hppa ~ppc ~ppc64 ~sparc ~x86"
119 +fi
120 +
121 +SRC_URI="
122 + http://www.shorewall.net/pub/shorewall/${MY_URL_PREFIX}${MY_MAJOR_RELEASE_NUMBER}/shorewall-${MY_MAJORMINOR_RELEASE_NUMBER}${MY_URL_SUFFIX}/shorewall-core-${MY_PV}.tar.bz2
123 + ipv4? ( http://www.shorewall.net/pub/shorewall/${MY_URL_PREFIX}${MY_MAJOR_RELEASE_NUMBER}/shorewall-${MY_MAJORMINOR_RELEASE_NUMBER}${MY_URL_SUFFIX}/shorewall-${MY_PV}.tar.bz2 )
124 + ipv6? ( http://www.shorewall.net/pub/shorewall/${MY_URL_PREFIX}${MY_MAJOR_RELEASE_NUMBER}/shorewall-${MY_MAJORMINOR_RELEASE_NUMBER}${MY_URL_SUFFIX}/shorewall6-${MY_PV}.tar.bz2 )
125 + lite4? ( http://www.shorewall.net/pub/shorewall/${MY_URL_PREFIX}${MY_MAJOR_RELEASE_NUMBER}/shorewall-${MY_MAJORMINOR_RELEASE_NUMBER}${MY_URL_SUFFIX}/shorewall-lite-${MY_PV}.tar.bz2 )
126 + lite6? ( http://www.shorewall.net/pub/shorewall/${MY_URL_PREFIX}${MY_MAJOR_RELEASE_NUMBER}/shorewall-${MY_MAJORMINOR_RELEASE_NUMBER}${MY_URL_SUFFIX}/shorewall6-lite-${MY_PV}.tar.bz2 )
127 + init? ( http://www.shorewall.net/pub/shorewall/${MY_URL_PREFIX}${MY_MAJOR_RELEASE_NUMBER}/shorewall-${MY_MAJORMINOR_RELEASE_NUMBER}${MY_URL_SUFFIX}/shorewall-init-${MY_PV}.tar.bz2 )
128 + doc? ( http://www.shorewall.net/pub/shorewall/${MY_URL_PREFIX}${MY_MAJOR_RELEASE_NUMBER}/shorewall-${MY_MAJORMINOR_RELEASE_NUMBER}${MY_URL_SUFFIX}/${MY_P_DOCS}.tar.bz2 )
129 +"
130 +
131 +# - Shorewall6 requires Shorewall
132 +# - Installing Shorewall-init or just the documentation doesn't make any sense,
133 +# that's why we force the user to select at least one "real" Shorewall product
134 +#
135 +# See http://shorewall.net/download.htm#Which
136 +REQUIRED_USE="
137 + ipv6? ( ipv4 )
138 + || ( ipv4 lite4 lite6 )
139 +"
140 +
141 +# No build dependencies! Just plain shell scripts...
142 +DEPEND=""
143 +
144 +RDEPEND="
145 + >=net-firewall/iptables-1.4.20
146 + >=sys-apps/iproute2-3.8.0[-minimal]
147 + >=sys-devel/bc-1.06.95
148 + ipv4? (
149 + >=dev-lang/perl-5.16
150 + virtual/perl-Digest-SHA
151 + )
152 + ipv6? (
153 + >=dev-perl/Socket6-0.230.0
154 + >=net-firewall/iptables-1.4.20[ipv6]
155 + >=sys-apps/iproute2-3.8.0[ipv6]
156 + )
157 + lite6? (
158 + >=net-firewall/iptables-1.4.20[ipv6]
159 + >=sys-apps/iproute2-3.8.0[ipv6]
160 + )
161 + init? ( >=sys-apps/coreutils-8.20 )
162 + selinux? ( >=sec-policy/selinux-shorewall-2.20161023-r3 )
163 + !net-firewall/shorewall-core
164 + !net-firewall/shorewall6
165 + !net-firewall/shorewall-lite
166 + !net-firewall/shorewall6-lite
167 + !net-firewall/shorewall-init
168 + !<sys-apps/systemd-214
169 +"
170 +
171 +S=${WORKDIR}
172 +
173 +pkg_pretend() {
174 + local CONFIG_CHECK="~NF_CONNTRACK"
175 +
176 + local WARNING_CONNTRACK="Without NF_CONNTRACK support, you will be unable"
177 + local WARNING_CONNTRACK+=" to run any shorewall-based firewall on the local system."
178 +
179 + if use ipv4 || use lite4; then
180 + CONFIG_CHECK="${CONFIG_CHECK} ~NF_CONNTRACK_IPV4"
181 +
182 + local WARNING_CONNTRACK_IPV4="Without NF_CONNTRACK_IPV4 support, you will"
183 + local WARNING_CONNTRACK_IPV4+=" be unable to run any shorewall-based IPv4 firewall on the local system."
184 + fi
185 +
186 + if use ipv6 || use lite6; then
187 + CONFIG_CHECK="${CONFIG_CHECK} ~NF_CONNTRACK_IPV6"
188 +
189 + local WARNING_CONNTRACK_IPV6="Without NF_CONNTRACK_IPV6 support, you will"
190 + local WARNING_CONNTRACK_IPV6+=" be unable to run any shorewall-based IPv6 firewall on the local system."
191 + fi
192 +
193 + check_extra_config
194 +}
195 +
196 +pkg_setup() {
197 + if [[ -n "${DIGEST}" ]]; then
198 + einfo "Unsetting environment variable \"DIGEST\" to prevent conflicts with package's \"install.sh\" script ..."
199 + unset DIGEST
200 + fi
201 +}
202 +
203 +src_prepare() {
204 + # We are moving each unpacked source from MY_P_* to MY_PN_*.
205 + # This allows us to use patches from upstream and keeps epatch_user working
206 +
207 + einfo "Preparing shorewallrc ..."
208 + cp "${FILESDIR}"/shorewallrc-r3 "${S}"/shorewallrc.gentoo || die "Copying shorewallrc failed"
209 + eprefixify "${S}"/shorewallrc.gentoo
210 + sed -i \
211 + -e "s|SERVICEDIR=tbs|SERVICEDIR=$(systemd_get_systemunitdir)|" \
212 + "${S}"/shorewallrc.gentoo || die "Failed to update shorewallrc"
213 +
214 + # shorewall-core
215 + mv "${S}"/${MY_P_CORE} "${S}"/${MY_PN_CORE} || die "Failed to move '${S}/${MY_P_CORE}' to '${S}/${MY_PN_CORE}'"
216 + ebegin "Applying Gentoo-specific changes to ${MY_P_CORE} ..."
217 + ln -s ../shorewallrc.gentoo ${MY_PN_CORE}/shorewallrc.gentoo || die "Failed to symlink shorewallrc.gentoo"
218 + eend 0
219 +
220 + pushd "${S}"/${MY_PN_CORE} &>/dev/null || die
221 + eapply "${FILESDIR}"/shorewall-core-5.2.1-no-gzipped-manpages.patch
222 + popd &>/dev/null || die
223 +
224 + # shorewall
225 + if use ipv4; then
226 + mv "${S}"/${MY_P_IPV4} "${S}"/${MY_PN_IPV4} || die "Failed to move '${S}/${MY_P_IPV4}' to '${S}/${MY_PN_IPV4}'"
227 + ebegin "Applying Gentoo-specific changes to ${MY_P_IPV4}"
228 + ln -s ../shorewallrc.gentoo ${MY_PN_IPV4}/shorewallrc.gentoo || die "Failed to symlink shorewallrc.gentoo"
229 + cp "${FILESDIR}"/shorewall.confd-r1 "${S}"/${MY_PN_IPV4}/default.gentoo || die "Copying shorewall.confd-r1 failed"
230 + cp "${FILESDIR}"/shorewall.initd-r3 "${S}"/${MY_PN_IPV4}/init.gentoo.sh || die "Copying shorewall.initd-r2 failed"
231 + cp "${FILESDIR}"/shorewall.systemd "${S}"/${MY_PN_IPV4}/gentoo.service || die "Copying shorewall.systemd failed"
232 + eend 0
233 +
234 + pushd "${S}"/${MY_PN_IPV4} &>/dev/null || die
235 + eapply "${FILESDIR}"/shorewall-5.2.1-no-gzipped-manpages.patch
236 + popd &>/dev/null || die
237 + fi
238 +
239 + # shorewall6
240 + if use ipv6; then
241 + mv "${S}"/${MY_P_IPV6} "${S}"/${MY_PN_IPV6} || die "Failed to move '${S}/${MY_P_IPV6}' to '${S}/${MY_PN_IPV6}'"
242 + ebegin "Applying Gentoo-specific changes to ${MY_P_IPV6}"
243 + ln -s ../shorewallrc.gentoo ${MY_PN_IPV6}/shorewallrc.gentoo || die "Failed to symlink shorewallrc.gentoo"
244 + cp "${FILESDIR}"/shorewall.confd-r1 "${S}"/${MY_PN_IPV6}/default.gentoo || die "Copying shorewall.confd-r1 failed"
245 + cp "${FILESDIR}"/shorewall.initd-r3 "${S}"/${MY_PN_IPV6}/init.gentoo.sh || die "Copying shorewall.initd-r2 failed"
246 + cp "${FILESDIR}"/shorewall6.systemd "${S}"/${MY_PN_IPV6}/gentoo.service || die "Copying shorewall6.systemd failed"
247 + eend 0
248 +
249 + pushd "${S}"/${MY_PN_IPV6} &>/dev/null || die
250 + eapply "${FILESDIR}"/shorewall-5.2.1-no-gzipped-manpages.patch
251 + popd &>/dev/null || die
252 + fi
253 +
254 + # shorewall-lite
255 + if use lite4; then
256 + mv "${S}"/${MY_P_LITE4} "${S}"/${MY_PN_LITE4} || die "Failed to move '${S}/${MY_P_LITE4}' to '${S}/${MY_PN_LITE4}'"
257 + ebegin "Applying Gentoo-specific changes to ${MY_P_LITE4}"
258 + ln -s ../shorewallrc.gentoo ${MY_PN_LITE4}/shorewallrc.gentoo || die "Failed to symlink shorewallrc.gentoo"
259 + cp "${FILESDIR}"/shorewall-lite.confd-r1 "${S}"/${MY_PN_LITE4}/default.gentoo || die "Copying shorewall-lite.confd-r1 failed"
260 + cp "${FILESDIR}"/shorewall-lite.initd-r3 "${S}"/${MY_PN_LITE4}/init.gentoo.sh || die "Copying shorewall-lite.initd-r2 failed"
261 + cp "${FILESDIR}"/shorewall-lite.systemd "${S}"/${MY_PN_LITE4}/gentoo.service || die "Copying shorewall-lite.systemd failed"
262 + eend 0
263 +
264 + pushd "${S}"/${MY_PN_LITE4} &>/dev/null || die
265 + eapply "${FILESDIR}"/shorewall-lite-5.2.1-no-gzipped-manpages.patch
266 + popd &>/dev/null || die
267 + fi
268 +
269 + # shorewall6-lite
270 + if use lite6; then
271 + mv "${S}"/${MY_P_LITE6} "${S}"/${MY_PN_LITE6} || die "Failed to move '${S}/${MY_P_LITE6}' to '${S}/${MY_PN_LITE6}'"
272 + ebegin "Applying Gentoo-specific changes to ${MY_P_LITE6}"
273 + ln -s ../shorewallrc.gentoo ${MY_PN_LITE6}/shorewallrc.gentoo || die "Failed to symlink shorewallrc.gentoo"
274 + cp "${FILESDIR}"/shorewall-lite.confd-r1 "${S}"/${MY_PN_LITE6}/default.gentoo || die "Copying shorewall-lite.confd-r1 failed"
275 + cp "${FILESDIR}"/shorewall-lite.initd-r3 "${S}"/${MY_PN_LITE6}/init.gentoo.sh || die "Copying shorewall-lite.initd-r2 failed"
276 + cp "${FILESDIR}"/shorewall6-lite.systemd "${S}"/${MY_PN_LITE6}/gentoo.service || die "Copying shorewall6-lite.systemd failed"
277 + eend 0
278 +
279 + pushd "${S}"/${MY_PN_LITE6} &>/dev/null || die
280 + eapply "${FILESDIR}"/shorewall-lite-5.2.1-no-gzipped-manpages.patch
281 + popd &>/dev/null || die
282 + fi
283 +
284 + # shorewall-init
285 + if use init; then
286 + mv "${S}"/${MY_P_INIT} "${S}"/${MY_PN_INIT} || die "Failed to move '${S}/${MY_P_INIT}' to '${S}/${MY_PN_INIT}'"
287 + ebegin "Applying Gentoo-specific changes to ${MY_P_INIT}"
288 + ln -s ../shorewallrc.gentoo ${MY_PN_INIT}/shorewallrc.gentoo || die "Failed to symlink shorewallrc.gentoo"
289 + cp "${FILESDIR}"/shorewall-init.confd "${S}"/${MY_PN_INIT}/default.gentoo || die "Copying shorewall-init.confd failed"
290 + cp "${FILESDIR}"/shorewall-init.initd "${S}"/${MY_PN_INIT}/init.gentoo.sh || die "Copying shorewall-init.initd failed"
291 + cp "${FILESDIR}"/shorewall-init.systemd "${S}"/${MY_PN_INIT}/gentoo.service || die "Copying shorewall-init.systemd failed"
292 + cp "${FILESDIR}"/shorewall-init.readme "${S}"/${MY_PN_INIT}/shorewall-init.README.Gentoo.txt || die "Copying shorewall-init.systemd failed"
293 + eend 0
294 +
295 + eprefixify "${S}"/${MY_PN_INIT}/init.gentoo.sh
296 +
297 + pushd "${S}"/${MY_PN_INIT} &>/dev/null || die
298 + eapply -p2 "${FILESDIR}"/shorewall-init-01_remove-ipset-functionality-r1.patch
299 + popd &>/dev/null || die
300 + fi
301 +
302 + # shorewall-docs-html
303 + if use doc; then
304 + mv "${S}"/${MY_P_DOCS} "${S}"/${MY_PN_DOCS} || die "Failed to move '${S}/${MY_P_DOCS}' to '${S}/${MY_PN_DOCS}'"
305 + fi
306 +
307 + eapply_user
308 +}
309 +
310 +src_configure() {
311 + :;
312 +}
313 +
314 +src_compile() {
315 + :;
316 +}
317 +
318 +src_install() {
319 + # shorewall-core
320 + einfo "Installing ${MY_P_CORE} ..."
321 + DESTDIR="${D%/}" ${MY_PN_CORE}/install.sh shorewallrc.gentoo || die "${MY_PN_CORE}/install.sh failed"
322 + dodoc "${S}"/${MY_PN_CORE}/changelog.txt "${S}"/${MY_PN_CORE}/releasenotes.txt
323 +
324 + # shorewall
325 + if use ipv4; then
326 + einfo "Installing ${MY_P_IPV4} ..."
327 + DESTDIR="${D%/}" ${MY_PN_IPV4}/install.sh shorewallrc.gentoo || die "${MY_PN_IPV4}/install.sh failed"
328 + keepdir /var/lib/shorewall
329 +
330 + if use doc; then
331 + dodoc -r "${S}"/${MY_PN_IPV4}/Samples
332 + fi
333 + fi
334 +
335 + # shorewall6
336 + if use ipv6; then
337 + einfo "Installing ${MY_P_IPV6} ..."
338 + DESTDIR="${D%/}" ${MY_PN_IPV6}/install.sh shorewallrc.gentoo || die "${MY_PN_IPV6}/install.sh failed"
339 + keepdir /var/lib/shorewall6
340 +
341 + if use doc; then
342 + dodoc -r "${S}"/${MY_PN_IPV6}/Samples6
343 + fi
344 + fi
345 +
346 + # shorewall-lite
347 + if use lite4; then
348 + einfo "Installing ${MY_P_LITE4} ..."
349 + DESTDIR="${D%/}" ${MY_PN_LITE4}/install.sh shorewallrc.gentoo || die "${MY_PN_LITE4}/install.sh failed"
350 + keepdir /var/lib/shorewall-lite
351 + fi
352 +
353 + # shorewall6-lite
354 + if use lite6; then
355 + einfo "Installing ${MY_P_LITE6} ..."
356 + DESTDIR="${D%/}" ${MY_PN_LITE6}/install.sh shorewallrc.gentoo || die "${MY_PN_LITE6}/install.sh failed"
357 + keepdir /var/lib/shorewall6-lite
358 + fi
359 +
360 + # shorewall-init
361 + if use init; then
362 + einfo "Installing ${MY_P_INIT} ..."
363 + DESTDIR="${D%/}" ${MY_PN_INIT}/install.sh shorewallrc.gentoo || die "${MY_PN_INIT}/install.sh failed"
364 + dodoc "${S}"/${MY_PN_INIT}/shorewall-init.README.Gentoo.txt
365 +
366 + if [[ -f "${D}etc/logrotate.d/shorewall-init" ]]; then
367 + # On Gentoo, shorewall-init will not create shorewall-ifupdown.log,
368 + # so we don't need a logrotate configuration file for shorewall-init
369 + einfo "Removing unused \"${D}etc/logrotate.d/shorewall-init\" ..."
370 + rm -rf "${D}"etc/logrotate.d/shorewall-init || die "Removing \"${D}etc/logrotate.d/shorewall-init\" failed"
371 + fi
372 +
373 + if [[ -d "${D}etc/NetworkManager" ]]; then
374 + # On Gentoo, we don't support NetworkManager
375 + # so we don't need this folder at all
376 + einfo "Removing unused \"${D}etc/NetworkManager\" ..."
377 + rm -rf "${D}"etc/NetworkManager || die "Removing \"${D}etc/NetworkManager\" failed"
378 + fi
379 +
380 + if [[ -f "${D}usr/share/shorewall-init/ifupdown" ]]; then
381 + # This script isn't supported on Gentoo
382 + rm -rf "${D}"usr/share/shorewall-init/ifupdown || die "Removing \"${D}usr/share/shorewall-init/ifupdown\" failed"
383 + fi
384 + fi
385 +
386 + if use doc; then
387 + einfo "Installing ${MY_P_DOCS} ..."
388 + docinto html && dodoc -r "${S}"/${MY_PN_DOCS}/*
389 + fi
390 +}
391 +
392 +pkg_postinst() {
393 + if [[ -z "${REPLACING_VERSIONS}" ]]; then
394 + # This is a new installation
395 +
396 + # Show first steps for shorewall/shorewall6
397 + local _PRODUCTS=""
398 + if use ipv4; then
399 + _PRODUCTS="shorewall"
400 +
401 + if use ipv6; then
402 + _PRODUCTS="${_PRODUCTS}/shorewall6"
403 + fi
404 + fi
405 +
406 + if [[ -n "${_PRODUCTS}" ]]; then
407 + elog "Before you can use ${_PRODUCTS}, you need to edit its configuration in:"
408 + elog ""
409 + elog " /etc/shorewall/shorewall.conf"
410 +
411 + if use ipv6; then
412 + elog " /etc/shorewall6/shorewall6.conf"
413 + fi
414 +
415 + elog ""
416 + elog "To activate your shorewall-based firewall on system start, please add ${_PRODUCTS} to your default runlevel:"
417 + elog ""
418 + elog " # rc-update add shorewall default"
419 +
420 + if use ipv6; then
421 + elog " # rc-update add shorewall6 default"
422 + fi
423 + fi
424 +
425 + # Show first steps for shorewall-lite/shorewall6-lite
426 + _PRODUCTS=""
427 + if use lite4; then
428 + _PRODUCTS="shorewall-lite"
429 + fi
430 +
431 + if use lite6; then
432 + if [[ -z "${_PRODUCTS}" ]]; then
433 + _PRODUCTS="shorewall6-lite"
434 + else
435 + _PRODUCTS="${_PRODUCTS}/shorewall6-lite"
436 + fi
437 + fi
438 +
439 + if [[ -n "${_PRODUCTS}" ]]; then
440 + if use ipv4; then
441 + elog ""
442 + fi
443 +
444 + elog "Before you can use ${_PRODUCTS}, you need to provide a configuration, which you can"
445 + elog "create using ${CATEGORY}/shorewall (with \"ipv4\" and or \"ipv6\" USE flag)."
446 + elog ""
447 + elog "To read more about ${_PRODUCTS}, please visit"
448 + elog " http://shorewall.net/CompiledPrograms.html"
449 + elog ""
450 + elog "To activate your shorewall-lite-based firewall on system start, please add ${PRODUCTS} to your default runlevel:"
451 + elog ""
452 +
453 + if use lite4; then
454 + elog " # rc-update add shorewall-lite default"
455 + fi
456 +
457 + if use lite6; then
458 + elog " # rc-update add shorewall6-lite default"
459 + fi
460 + fi
461 +
462 + if use init; then
463 + elog ""
464 + elog "To secure your system on boot, please add shorewall-init to your boot runlevel:"
465 + elog ""
466 + elog " # rc-update add shorewall-init boot"
467 + elog ""
468 + elog "and review \$PRODUCTS in"
469 + elog ""
470 + elog " /etc/conf.d/shorewall-init"
471 + fi
472 +
473 + fi
474 +
475 + local v
476 + for v in ${REPLACING_VERSIONS}; do
477 + if ! version_is_at_least ${MY_MAJOR_RELEASE_NUMBER} ${v}; then
478 + # This is an upgrade
479 +
480 + elog "You are upgrading from a previous major version. It is highly recommended that you read"
481 + elog ""
482 + elog " - /usr/share/doc/shorewall*/releasenotes.tx*"
483 + elog " - http://shorewall.net/Shorewall-5.html#idm214"
484 +
485 + if use ipv4; then
486 + elog ""
487 + elog "You can auto-migrate your configuration using"
488 + elog ""
489 + elog " # shorewall update -A"
490 +
491 + if use ipv6; then
492 + elog " # shorewall6 update -A"
493 + fi
494 +
495 + elog ""
496 + elog "*after* you have merged the changed files using one of the configuration"
497 + elog "files update tools of your choice (dispatch-conf, etc-update...)."
498 +
499 + elog ""
500 + elog "But if you are not familiar with the \"shorewall[6] update\" command,"
501 + elog "please read the shorewall[6] man page first."
502 + fi
503 +
504 + # Show this elog only once
505 + break
506 + fi
507 + done
508 +
509 + if ! use init; then
510 + elog ""
511 + elog "Consider emerging ${CATEGORY}/${PN} with USE flag \"init\" to secure your system on boot"
512 + elog "before your shorewall-based firewall is ready to start."
513 + elog ""
514 + elog "To read more about shorewall-init, please visit"
515 + elog " http://www.shorewall.net/Shorewall-init.html"
516 + fi
517 +
518 + if ! has_version "net-firewall/conntrack-tools"; then
519 + elog ""
520 + elog "Your Shorewall firewall can utilize \"conntrack\" from the \"net-firewall/conntrack-tools\""
521 + elog "package. if you want to use this feature, you need to install \"net-firewall/conntrack-tools\"!"
522 + fi
523 +
524 + if ! has_version "dev-perl/Devel-NYTProf"; then
525 + elog ""
526 + elog "If you want to profile your Shorewall firewall you need to install \"dev-perl/Devel-NYTProf\"!"
527 + fi
528 +}