From c342738a0712e90d49a949c61cc453304c92f5b5 Mon Sep 17 00:00:00 2001 From: glitsj16 Date: Mon, 23 Dec 2019 22:54:58 +0000 Subject: Add ephemeral profile (#3094) * Create ephemeral.profile * Add ephemeral.profile * Add ephemeral.profile --- etc/disable-programs.inc | 1 + etc/ephemeral.profile | 61 ++++++++++++++++++++++++++++++++++++++++++++++ src/firecfg/firecfg.config | 1 + 3 files changed, 63 insertions(+) create mode 100644 etc/ephemeral.profile diff --git a/etc/disable-programs.inc b/etc/disable-programs.inc index 8eb7176e9..b1605e757 100644 --- a/etc/disable-programs.inc +++ b/etc/disable-programs.inc @@ -723,6 +723,7 @@ blacklist ${HOME}/.cache/darktable blacklist ${HOME}/.cache/discover blacklist ${HOME}/.cache/dnox blacklist ${HOME}/.cache/dolphin +blacklist ${HOME}/.cache/ephemeral blacklist ${HOME}/.cache/epiphany blacklist ${HOME}/.cache/evolution blacklist ${HOME}/.cache/falkon diff --git a/etc/ephemeral.profile b/etc/ephemeral.profile new file mode 100644 index 000000000..fa7746da5 --- /dev/null +++ b/etc/ephemeral.profile @@ -0,0 +1,61 @@ +# Firejail profile for ephemeral +# Description: The always-incognito web browser +# This file is overwritten after every install/update +# Persistent local customizations +include ephemeral.local +# Persistent global definitions +include globals.local + +# enforce private-cache +#noblacklist ${HOME}/.cache/ephemeral + +noblacklist ${HOME}/.pki +noblacklist ${HOME}/.local/share/pki + +# noexec ${HOME} breaks DRM binaries. +?BROWSER_ALLOW_DRM: ignore noexec ${HOME} + +include disable-common.inc +include disable-devel.inc +include disable-exec.inc +include disable-interpreters.inc +include disable-programs.inc + +# enforce private-cache +#mkdir ${HOME}/.cache/ephemeral +mkdir ${HOME}/.pki +mkdir ${HOME}/.local/share/pki +# enforce private-cache +#whitelist ${HOME}/.cache/ephemeral +whitelist ${HOME}/.pki +whitelist ${HOME}/.local/share/pki +whitelist ${DOWNLOADS} +include whitelist-common.inc +include whitelist-usr-share-common.inc +include whitelist-var-common.inc + +apparmor +caps.drop all +# machine-id breaks pulse audio; it should work fine in setups where sound is not required. +#machine-id +netfilter +# nodbus breaks preferences +#nodbus +nodvd +nogroups +nonewprivs +# noroot breaks GTK_USE_PORTAL=1 usage, see https://github.com/netblue30/firejail/issues/2506. +noroot +notv +?BROWSER_DISABLE_U2F: nou2f +protocol unix,inet,inet6,netlink +seccomp +shell none +tracelog + +disable-mnt +private-cache +private-dev +# private-etc below works fine on most distributions. There are some problems on CentOS. +#private-etc alternatives,asound.conf,ca-certificates,crypto-policies,dconf,fonts,group,gtk-2.0,gtk-3.0,hostname,hosts,ld.so.cache,localtime,login.defs,machine-id,mailcap,mime.types,nsswitch.conf,os-release,pango,passwd,pki,pulse,resolv.conf,selinux,ssl,X11,xdg +private-tmp diff --git a/src/firecfg/firecfg.config b/src/firecfg/firecfg.config index 745c3f235..e8ec20273 100644 --- a/src/firecfg/firecfg.config +++ b/src/firecfg/firecfg.config @@ -176,6 +176,7 @@ enox enpass eog eom +ephemeral #epiphany etr evince -- cgit v1.2.3-70-g09d2