apparmor.d/apparmor.d/groups/kde/kioworker
2025-09-07 19:52:40 +02:00

111 lines
3 KiB
Text

# apparmor.d - Full set of apparmor profiles
# Copyright (C) 2023-2024 Alexandre Pujol <alexandre@pujol.io>
# SPDX-License-Identifier: GPL-2.0-only
abi <abi/4.0>,
include <tunables/global>
@{exec_path} = @{lib}/kf6/kioworker @{lib}/@{multiarch}/{,libexec/}kf6/kioworker
@{exec_path} += @{lib}/kf5/kioslave5 @{lib}/@{multiarch}/{,libexec/}kf5/kioslave5
profile kioworker @{exec_path} {
include <abstractions/base>
include <abstractions/bus-session>
include <abstractions/deny-sensitive-home>
include <abstractions/fontconfig-cache-write>
include <abstractions/graphics>
include <abstractions/kde-strict>
include <abstractions/nameservice-strict>
include <abstractions/ssl_certs>
include <abstractions/thumbnails-cache-write>
include <abstractions/trash-strict>
network inet dgram,
network inet6 dgram,
network inet stream,
network inet6 stream,
network netlink raw,
network netlink dgram,
signal receive set=term peer=dolphin,
signal receive set=term peer=firefox-kmozillahelper,
signal receive set=term peer=plasma-discover,
signal receive set=term peer=plasmashell,
signal receive set=term peer=xdg-desktop-portal-kde,
#aa:dbus talk bus=session name=org.kde.kded5 path=/kded label=kded
@{exec_path} mr,
@{lib}/libheif/ r,
@{lib}/libheif/*.so* rm,
@{bin}/wrestool rPUx,
@{bin}/gs{,.bin} rix,
#aa:exec kio_http_cache_cleaner
/usr/share/kio_desktop/{,**} r,
/usr/share/kservices{5,6}/{,**} r,
/usr/share/kservicetypes{5,6}/*.desktop r,
/usr/share/remoteview/* r,
/usr/share/thumbnailers/{,**} r,
/etc/fstab r,
/etc/xdg/kioslaverc r,
/etc/xdg/menus/{,**} r,
# Full access to user's data
/ r,
/*/ r,
@{bin}/ r,
@{bin}/* r,
@{sbin}/ r,
@{sbin}/* r,
@{lib}/ r,
@{MOUNTDIRS}/ r,
@{MOUNTS}/ r,
@{MOUNTS}/** rw,
owner @{HOME}/{,**} rw,
owner @{run}/user/@{uid}/{,**} rw,
owner @{tmp}/{,**} rw,
# Silence non user's data
deny @{efi}/{,**} r,
deny /etc/{,**} r,
deny /opt/{,**} r,
deny /root/{,**} r,
deny /tmp/.* rw,
deny /tmp/.*/{,**} rw,
owner @{HOME}/@{XDG_DESKTOP_DIR}/.directory l -> @{HOME}/@{XDG_DESKTOP_DIR}/#@{int},
owner @{user_cache_dirs}/kio_http/* rwl,
owner @{user_config_dirs}/kio_httprc r,
owner @{user_config_dirs}/menus/{,**} r,
owner @{user_share_dirs}/baloo/index rw,
owner @{user_share_dirs}/baloo/index-lock rwk,
owner @{user_share_dirs}/kactivitymanagerd/resources/database rk,
owner @{user_share_dirs}/kactivitymanagerd/resources/database-shm rwk,
owner @{user_share_dirs}/kactivitymanagerd/resources/database-wal rw,
owner @{user_share_dirs}/kservices{5,6}/{,**} r,
owner @{tmp}/#@{int} rw,
@{run}/mount/utab r,
owner @{run}/user/@{uid}/#@{int} rw,
owner @{run}/user/@{uid}/kio_*.socket rwl -> @{run}/user/@{uid}/#@{int},
owner @{run}/user/@{uid}/kioworker*.kioworker.socket rwl -> @{run}/user/@{uid}/#@{int},
owner @{PROC}/@{pid}/cmdline r,
owner @{PROC}/@{pid}/mountinfo r,
owner @{PROC}/@{pid}/mounts r,
/dev/tty r,
include if exists <local/kioworker>
}
# vim:syntax=apparmor