190 lines
6.2 KiB
Text
190 lines
6.2 KiB
Text
# apparmor.d - Full set of apparmor profiles
|
|
# Copyright (C) 2022-2024 Alexandre Pujol <alexandre@pujol.io>
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
|
# LOGPROF-SUGGEST: no
|
|
|
|
# Full set of rules for all chromium based browsers. It works as a *function*
|
|
# and requires some variables to be provided as *arguments* and set in the
|
|
# header of the calling profile. Example:
|
|
#
|
|
# @{name} = chromium
|
|
# @{domain} = org.chromium.Chromium
|
|
# @{lib_dirs} = @{lib}/chromium
|
|
# @{config_dirs} = @{user_config_dirs}/chromium
|
|
# @{cache_dirs} = @{user_cache_dirs}/chromium
|
|
#
|
|
# If your application requires chromium to run use abstractions/common/chromium
|
|
# or abstractions/common/electron instead.
|
|
#
|
|
|
|
abi <abi/4.0>,
|
|
|
|
include <abstractions/audio-client>
|
|
include <abstractions/bus-session>
|
|
include <abstractions/bus-system>
|
|
include <abstractions/bus/org.bluez>
|
|
include <abstractions/bus/org.freedesktop.Avahi>
|
|
include <abstractions/bus/org.freedesktop.FileManager1>
|
|
include <abstractions/bus/org.freedesktop.secrets>
|
|
include <abstractions/bus/org.freedesktop.UPower>
|
|
include <abstractions/bus/org.gnome.Mutter.IdleMonitor>
|
|
include <abstractions/bus/org.gnome.SessionManager>
|
|
include <abstractions/bus/org.kde.kwalletd>
|
|
include <abstractions/camera>
|
|
include <abstractions/common/chromium>
|
|
include <abstractions/dconf-write>
|
|
include <abstractions/desktop>
|
|
include <abstractions/devices-usb>
|
|
include <abstractions/fontconfig-cache-read>
|
|
include <abstractions/graphics>
|
|
include <abstractions/nameservice-strict>
|
|
include <abstractions/notifications>
|
|
include <abstractions/screensaver>
|
|
include <abstractions/ssl_certs>
|
|
include <abstractions/thumbnails-cache-read>
|
|
include <abstractions/uim>
|
|
include <abstractions/user-download-strict>
|
|
include <abstractions/user-read-strict>
|
|
|
|
network inet dgram,
|
|
network inet6 dgram,
|
|
network inet stream,
|
|
network inet6 stream,
|
|
network netlink raw,
|
|
|
|
signal (receive) peer=@{profile_name}-crashpad-handler,
|
|
signal (send) set=(term, kill) peer=@{profile_name}-sandbox,
|
|
signal (send) set=(term, kill) peer=keepassxc-proxy,
|
|
|
|
ptrace (read) peer=browserpass,
|
|
ptrace (read) peer=chrome-gnome-shell,
|
|
ptrace (read) peer=gnome-browser-connector-host,
|
|
ptrace (read) peer=keepassxc-proxy,
|
|
ptrace (read) peer=lsb_release,
|
|
ptrace (read) peer=plasma-browser-integration-host,
|
|
ptrace (read) peer=xdg-settings,
|
|
ptrace (trace) peer=@{profile_name},
|
|
|
|
@{lib_dirs}/{,**} r,
|
|
@{lib_dirs}/*.so* mr,
|
|
@{lib_dirs}/chrome-sandbox rPx,
|
|
|
|
# Desktop integration
|
|
@{bin}/lsb_release rPx,
|
|
@{bin}/xdg-desktop-menu rPx,
|
|
@{bin}/xdg-email rPx,
|
|
@{bin}/xdg-icon-resource rPx,
|
|
@{bin}/xdg-mime rPx,
|
|
@{bin}/xdg-open rPx -> child-open,
|
|
@{bin}/xdg-settings rPx,
|
|
|
|
# Installing/removing extensions, applications, and stacked xdg menus
|
|
@{sh_path} rix,
|
|
@{bin}/{,e}grep ix,
|
|
@{bin}/{m,g,}awk ix,
|
|
@{coreutils_path} ix,
|
|
|
|
# For storing passwords externally
|
|
@{bin}/keepassxc-proxy rix, # as a temporary solution - see issue #128
|
|
@{bin}/browserpass rPx,
|
|
|
|
# Gnome shell integration
|
|
@{bin}/chrome-gnome-shell rPx,
|
|
@{bin}/gnome-browser-connector-host rPx,
|
|
|
|
# Plasma integration
|
|
@{bin}/plasma-browser-integration-host rPx,
|
|
|
|
/usr/share/@{name}/{,**} r,
|
|
/usr/share/chromium/extensions/{,**} r,
|
|
/usr/share/mozilla/extensions/{,**} r,
|
|
/usr/share/webext/{,**} r,
|
|
|
|
/etc/@{name}/{,**} r,
|
|
/etc/fstab r,
|
|
/etc/{,opensc/}opensc.conf r,
|
|
|
|
/ r,
|
|
owner @{HOME}/ r,
|
|
|
|
owner @{user_cache_dirs}/gtk-3.0/**/*.cache r,
|
|
owner @{user_config_dirs}/gtk-3.0/servers r,
|
|
|
|
owner @{user_share_dirs}/icons/hicolor/.xdg-icon-resource-dummy w,
|
|
|
|
owner @{config_dirs}/ rw,
|
|
owner @{config_dirs}/** rwk,
|
|
owner @{config_dirs}/WidevineCdm/*/_platform_specific/linux_*/libwidevinecdm.so mrw,
|
|
|
|
owner @{cache_dirs}/{,**} rw,
|
|
|
|
owner @{user_config_dirs}/kioslaverc r,
|
|
owner @{user_config_dirs}/menus/applications-merged/ r,
|
|
owner @{user_config_dirs}/menus/applications-merged/*.menu rw,
|
|
|
|
# For importing data (bookmarks, cookies, etc) from Firefox
|
|
# owner @{HOME}/.mozilla/firefox/profiles.ini r,
|
|
# owner @{HOME}/.mozilla/firefox/*/ r,
|
|
# owner @{HOME}/.mozilla/firefox/*/compatibility.ini r,
|
|
# owner @{HOME}/.mozilla/firefox/*/search{,-metadata}.json r,
|
|
# owner @{HOME}/.mozilla/firefox/*/.parentlock rwk,
|
|
# owner @{HOME}/.mozilla/firefox/*/{places,cookies,favicons,formhistory,}.sqlite{,-wal,-shm,-journal} rwk,
|
|
# owner @{HOME}/.mozilla/firefox/*/{cert9,key4}.db rwk,
|
|
# owner @{HOME}/.mozilla/firefox/*/logins.json r,
|
|
|
|
/tmp/ r,
|
|
/var/tmp/ r,
|
|
owner @{tmp}/@{name}-crashlog-@{int}-@{int}.txt rw,
|
|
owner @{tmp}/tmp.@{rand10} rw,
|
|
owner @{tmp}/tmp.@{rand6} rw,
|
|
owner @{tmp}/tmp.@{rand6}/ rw,
|
|
owner @{tmp}/tmp.@{rand6}/** rwk,
|
|
|
|
owner @{run}/user/@{uid}/app/org.keepassxc.KeePassXC/org.keepassxc.KeePassXC.BrowserServer rw,
|
|
owner @{run}/user/@{uid}/org.keepassxc.KeePassXC.BrowserServer rw,
|
|
|
|
@{run}/udev/data/c13:@{int} r, # for /dev/input/*
|
|
|
|
@{sys}/bus/ r,
|
|
@{sys}/bus/**/devices/ r,
|
|
@{sys}/class/**/ r,
|
|
@{sys}/devices/@{pci}/{in_intensity_sampling_frequency,in_intensity_scale,in_illuminance_raw} r,
|
|
@{sys}/devices/@{pci}/boot_vga r,
|
|
@{sys}/devices/@{pci}/report_descriptor r,
|
|
@{sys}/devices/**/uevent r,
|
|
@{sys}/devices/virtual/**/report_descriptor r,
|
|
|
|
@{PROC}/ r,
|
|
@{PROC}/@{pid}/fd/ r,
|
|
@{PROC}/@{pid}/stat r,
|
|
@{PROC}/@{pid}/statm r,
|
|
@{PROC}/@{pid}/task/@{tid}/status r,
|
|
@{PROC}/pressure/{memory,cpu,io} r,
|
|
@{PROC}/sys/fs/inotify/max_user_watches r,
|
|
@{PROC}/sys/kernel/yama/ptrace_scope r,
|
|
@{PROC}/vmstat r,
|
|
owner @{PROC}/@{pid}/clear_refs w,
|
|
owner @{PROC}/@{pid}/cmdline r,
|
|
owner @{PROC}/@{pid}/environ r,
|
|
owner @{PROC}/@{pid}/limits r,
|
|
owner @{PROC}/@{pid}/mem r,
|
|
owner @{PROC}/@{pid}/mountinfo r,
|
|
owner @{PROC}/@{pid}/mounts r,
|
|
owner @{PROC}/@{pid}/oom_{,score_}adj rw,
|
|
owner @{PROC}/@{pid}/smaps_rollup r,
|
|
owner @{PROC}/@{pid}/task/ r,
|
|
owner @{PROC}/@{pid}/task/@{tid}/comm rw,
|
|
owner @{PROC}/@{pid}/task/@{tid}/stat r,
|
|
|
|
/dev/ r,
|
|
/dev/hidraw@{int} rw,
|
|
/dev/tty rw,
|
|
owner /dev/tty@{int} rw,
|
|
|
|
# Silencer
|
|
deny @{lib_dirs}/** w,
|
|
deny @{user_share_dirs}/gvfs-metadata/* r,
|
|
|
|
include if exists <abstractions/app/chromium.d>
|
|
|
|
# vim:syntax=apparmor
|