91 lines
2.8 KiB
Text
91 lines
2.8 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>
|
|
|
|
@{share_dirs} = /usr/share/gnome-shell/extensions/gsconnect@andyholmes.github.io
|
|
@{share_dirs} += @{user_share_dirs}/gnome-shell/extensions/gsconnect@andyholmes.github.io
|
|
|
|
@{exec_path} = @{share_dirs}/service/daemon.js @{share_dirs}/gsconnect-preferences
|
|
profile gnome-extension-gsconnect @{exec_path} {
|
|
include <abstractions/base>
|
|
include <abstractions/audio-client>
|
|
include <abstractions/bus-accessibility>
|
|
include <abstractions/bus-session>
|
|
include <abstractions/bus-system>
|
|
include <abstractions/bus/org.a11y>
|
|
include <abstractions/bus/org.freedesktop.FileManager1>
|
|
include <abstractions/bus/org.freedesktop.hostname1>
|
|
include <abstractions/bus/org.freedesktop.login1.Session>
|
|
include <abstractions/bus/org.freedesktop.NetworkManager>
|
|
include <abstractions/bus/session/org.gtk.Private.RemoteVolumeMonitor>
|
|
include <abstractions/bus/session/org.gtk.vfs.Daemon>
|
|
include <abstractions/bus/session/org.mpris.MediaPlayer2.Player>
|
|
include <abstractions/bus/session/org.gtk.vfs.MountOperation>
|
|
include <abstractions/dconf-write>
|
|
include <abstractions/gnome-strict>
|
|
include <abstractions/nameservice-strict>
|
|
include <abstractions/notifications>
|
|
include <abstractions/p11-kit>
|
|
include <abstractions/ssl_certs>
|
|
include <abstractions/user-download-strict>
|
|
|
|
network inet dgram,
|
|
network inet6 dgram,
|
|
network inet stream,
|
|
network inet6 stream,
|
|
network netlink raw,
|
|
|
|
#aa:dbus own bus=session name=org.gnome.Shell.Extensions.GSConnect interface+=org.gtk.{Actions,Menus}
|
|
|
|
dbus eavesdrop bus=session,
|
|
|
|
@{exec_path} mr,
|
|
|
|
@{sh_path} rix,
|
|
@{bin}/env rix,
|
|
@{bin}/gjs-console rix,
|
|
@{bin}/openssl rix,
|
|
@{bin}/ssh-add rix,
|
|
|
|
@{bin}/dconf rPx,
|
|
@{bin}/ssh-keygen rPx,
|
|
@{bin}/xdg-screensaver rPx,
|
|
|
|
@{lib}/gio/modules/*.so* rm,
|
|
@{lib}/girepository-1.0/* r,
|
|
|
|
@{open_path} rPx -> child-open-help,
|
|
|
|
@{share_dirs}/{,**} r,
|
|
@{share_dirs}/gsconnect-preferences rix,
|
|
|
|
owner @{user_cache_dirs}/gsconnect/{,**} rw,
|
|
|
|
owner @{user_config_dirs}/gsconnect/{,**} rw,
|
|
owner @{user_config_dirs}/mimeapps.list w,
|
|
owner @{user_config_dirs}/mimeapps.list.@{rand6} rw,
|
|
|
|
owner @{HOME}/.mozilla/firefox/firefox-mpris/@{word}.png r,
|
|
|
|
owner @{tmp}/.org.chromium.Chromium.@{rand6} r,
|
|
|
|
owner @{run}/user/@{uid}/gsconnect/{,**} rw,
|
|
owner @{run}/user/@{uid}/gvfsd/socket-@{rand8} rw,
|
|
owner @{run}/user/@{uid}/keyring/ssh rw,
|
|
|
|
@{sys}/devices/virtual/dmi/id/chassis_type r,
|
|
|
|
owner @{PROC}/@{pid}/mounts r,
|
|
owner @{PROC}/@{pid}/stat r,
|
|
owner @{PROC}/@{pid}/task/@{tid}/stat r,
|
|
|
|
deny @{user_share_dirs}/gvfs-metadata/* r,
|
|
|
|
include if exists <local/gnome-extension-gsconnect>
|
|
}
|
|
|
|
# vim:syntax=apparmor
|