diff options
author | Hank Leininger <hlein@korelogic.com> | 2022-02-21 12:15:13 -0700 |
---|---|---|
committer | Florian Schmaus <flow@gentoo.org> | 2022-02-22 10:43:45 +0100 |
commit | 0246df2ab9257ecb01fa6fc453a7c647cd1ca543 (patch) | |
tree | 8994675d4b2c3e068cb2631e0333abf276176124 /sys-apps | |
parent | dev-python/ipywidgets: Remove unnecessary jupyterlab_widgets dep (diff) | |
download | gentoo-0246df2ab9257ecb01fa6fc453a7c647cd1ca543.tar.gz gentoo-0246df2ab9257ecb01fa6fc453a7c647cd1ca543.tar.bz2 gentoo-0246df2ab9257ecb01fa6fc453a7c647cd1ca543.zip |
sys-apps/firejail: apply firecfg patch; misc cleanups
Update firecfg patch from my testing tree and apply it. Also
remove an obsolete use/configure flag.
Signed-off-by: Hank Leininger <hlein@korelogic.com>
Closes: https://bugs.gentoo.org/833596
Closes: https://github.com/gentoo/gentoo/pull/24299
Package-Manager: Portage-3.0.30, Repoman-3.0.3
Closes: https://github.com/gentoo/gentoo/pull/24305
Signed-off-by: Florian Schmaus <flow@gentoo.org>
Diffstat (limited to 'sys-apps')
-rw-r--r-- | sys-apps/firejail/files/firejail-0.9.68-firecfg.config.patch (renamed from sys-apps/firejail/files/firecfg.config.patch) | 32 | ||||
-rw-r--r-- | sys-apps/firejail/firejail-0.9.68-r1.ebuild | 118 |
2 files changed, 139 insertions, 11 deletions
diff --git a/sys-apps/firejail/files/firecfg.config.patch b/sys-apps/firejail/files/firejail-0.9.68-firecfg.config.patch index f4f5f34a196a..eaec87a108d5 100644 --- a/sys-apps/firejail/files/firecfg.config.patch +++ b/sys-apps/firejail/files/firejail-0.9.68-firecfg.config.patch @@ -1,6 +1,6 @@ ---- firecfg.config.orig 2021-11-05 20:30:20.451017470 -0600 -+++ firecfg.config 2022-02-06 20:53:53.948407229 -0700 -@@ -207,7 +207,8 @@ +--- a/src/firecfg/firecfg.config 2022-02-03 07:53:47.000000000 -0700 ++++ b/src/firecfg/firecfg.config 2022-02-21 11:56:00.267419833 -0700 +@@ -213,7 +213,8 @@ electron-mail electrum element-desktop @@ -10,17 +10,17 @@ empathy enchant enchant-2 -@@ -254,7 +255,8 @@ +@@ -259,7 +260,8 @@ + flameshot flashpeak-slimjet flowblade - font-manager -fontforge +# Breaks emerge/portage on Gentoo +#fontforge + font-manager fossamail four-in-a-row - fractal -@@ -478,11 +480,16 @@ +@@ -490,11 +492,16 @@ luminance-hdr lximage-qt lxmusic @@ -39,7 +39,7 @@ manaplus marker masterpdfeditor -@@ -558,7 +565,8 @@ +@@ -571,7 +578,8 @@ musictube musixmatch mutool @@ -49,17 +49,17 @@ mypaint mypaint-ora-thumbnailer natron -@@ -616,7 +624,8 @@ +@@ -632,7 +640,8 @@ palemoon #pandoc parole -patch -+# Breaks emerge/portage on Gentoo: 'too many environment variables' ++# Breaks emerge/portage on Gentoo: 'too many environment variables', path issues +#patch pavucontrol pavucontrol-qt pcsxr -@@ -736,7 +745,8 @@ +@@ -758,7 +767,8 @@ stellarium strawberry straw-viewer @@ -69,3 +69,13 @@ studio.sh subdownloader supertux2 +@@ -877,7 +887,8 @@ + weechat + weechat-curses + wesnoth +-wget ++# Breaks emerge/portage on Gentoo: 'too many environment variables', path issues ++#wget + wget2 + whalebird + whois diff --git a/sys-apps/firejail/firejail-0.9.68-r1.ebuild b/sys-apps/firejail/firejail-0.9.68-r1.ebuild new file mode 100644 index 000000000000..5c5a610f1024 --- /dev/null +++ b/sys-apps/firejail/firejail-0.9.68-r1.ebuild @@ -0,0 +1,118 @@ +# Copyright 1999-2022 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +PYTHON_COMPAT=( python3_{8..10} ) + +inherit toolchain-funcs python-single-r1 linux-info + +if [[ ${PV} != 9999 ]]; then + SRC_URI="https://github.com/netblue30/${PN}/releases/download/${PV}/${P}.tar.xz" + KEYWORDS="~amd64 ~arm ~arm64 ~x86" +else + inherit git-r3 + EGIT_REPO_URI="https://github.com/netblue30/firejail.git" + EGIT_BRANCH="master" +fi + +DESCRIPTION="Security sandbox for any type of processes" +HOMEPAGE="https://firejail.wordpress.com/" + +LICENSE="GPL-2" +SLOT="0" +IUSE="apparmor +chroot contrib +dbusproxy +file-transfer +globalcfg +network +private-home test +userns X" +# Needs a lot of work to function within sandbox/portage +# bug #769731 +RESTRICT="test" + +RDEPEND="!sys-apps/firejail-lts + apparmor? ( sys-libs/libapparmor ) + contrib? ( ${PYTHON_DEPS} ) + dbusproxy? ( sys-apps/xdg-dbus-proxy )" + +DEPEND="${RDEPEND} + sys-libs/libseccomp + test? ( dev-tcltk/expect )" + +REQUIRED_USE="contrib? ( ${PYTHON_REQUIRED_USE} )" + +PATCHES=( + "${FILESDIR}/${P}-envlimits.patch" + "${FILESDIR}/${P}-firecfg.config.patch" + ) + +pkg_setup() { + CONFIG_CHECK="~SQUASHFS" + local ERROR_SQUASHFS="CONFIG_SQUASHFS: required for firejail --appimage mode" + check_extra_config + use contrib && python-single-r1_pkg_setup +} + +src_prepare() { + default + + find -type f -name Makefile.in -exec sed -i -r -e '/CFLAGS/s: (-O2|-ggdb) : :g' {} + || die + + sed -i -r -e '/CFLAGS/s: (-O2|-ggdb) : :g' ./src/common.mk.in || die + + # fix up hardcoded paths to templates and docs + local files=$(grep -E -l -r '/usr/share/doc/firejail([^-]|$)' ./RELNOTES ./src/man/ ./etc/profile*/ ./test/ || die) + for file in ${files[@]} ; do + sed -i -r -e "s:/usr/share/doc/firejail([^-]|\$):/usr/share/doc/${PF}\1:" "${file}" || die + done + + # remove compression of man pages + sed -i -r -e '/rm -f \$\$man.gz; \\/d; /gzip -9n \$\$man; \\/d; s|\*\.([[:digit:]])\) install -m 0644 \$\$man\.gz|\*\.\1\) install -m 0644 \$\$man|g' Makefile.in || die + + if use contrib; then + python_fix_shebang -f contrib/*.py + fi +} + +src_configure() { + econf \ + --disable-firetunnel \ + --enable-suid \ + $(use_enable apparmor) \ + $(use_enable chroot) \ + $(use_enable dbusproxy) \ + $(use_enable file-transfer) \ + $(use_enable globalcfg) \ + $(use_enable network) \ + $(use_enable private-home) \ + $(use_enable userns) \ + $(use_enable X x11) + + cat > 99firejail <<-EOF || die + SANDBOX_WRITE="/run/firejail" + EOF +} + +src_compile() { + emake CC="$(tc-getCC)" +} + +src_install() { + default + + # Gentoo-specific profile customizations + insinto /etc/${PN} + local profile_local + for profile_local in "${FILESDIR}"/profile_*local ; do + newins "${profile_local}" "${profile_local/\/*profile_/}" + done + + # Prevent sandbox violations when toolchain is firejailed + insinto /etc/sandbox.d + doins 99firejail + + rm "${ED}"/usr/share/doc/${PF}/COPYING || die + + if use contrib; then + python_scriptinto /usr/$(get_libdir)/firejail + python_doscript contrib/*.py + insinto /usr/$(get_libdir)/firejail + dobin contrib/*.sh + fi +} |