# apparmor.d - Full set of apparmor profiles # Copyright (C) 2022 Alexandre Pujol # SPDX-License-Identifier: GPL-2.0-only abi , include @{exec_path} = @{user_share_dirs}/Steam/steam.sh profile steam @{exec_path} { include include include include include include include include include include include include include include include include capability sys_ptrace, network inet dgram, network inet6 dgram, network inet stream, network inet6 stream, network netlink raw, ptrace (read), signal (send) peer=steam-game, signal (read), unix (receive) type=stream, @{exec_path} mrix, /{usr/,}bin/{,ba,da}sh rix, /{usr/,}bin/{m,g,}awk rix, /{usr/,}bin/*sum rix, /{usr/,}bin/basename rix, /{usr/,}bin/cat rix, /{usr/,}bin/cmp rix, /{usr/,}bin/cp rix, /{usr/,}bin/cut rix, /{usr/,}bin/dirname rix, /{usr/,}bin/file rix, /{usr/,}bin/find rix, /{usr/,}bin/getopt rix, /{usr/,}bin/grep rix, /{usr/,}bin/head rix, /{usr/,}bin/ldconfig rix, /{usr/,}bin/ldd rix, /{usr/,}bin/ln rix, /{usr/,}bin/lsb_release rPx -> lsb_release, /{usr/,}bin/lspci rCx -> lspci, /{usr/,}bin/mkdir rix, /{usr/,}bin/mv rix, /{usr/,}bin/readlink rix, /{usr/,}bin/realpath rix, /{usr/,}bin/rm rix, /{usr/,}bin/rmdir rix, /{usr/,}bin/sed rix, /{usr/,}bin/steam-runtime-urlopen rix, /{usr/,}bin/tail rix, /{usr/,}bin/tar rix, /{usr/,}bin/timeout rix, /{usr/,}bin/touch rix, /{usr/,}bin/tr rix, /{usr/,}bin/uname rix, /{usr/,}bin/which rix, /{usr/,}bin/xdg-icon-resource rPx, /{usr/,}bin/xdg-user-dir rPx, /{usr/,}bin/xz rix, /{usr/,}bin/zenity rix, /{usr/,}lib{32,64}/ld-linux.so* rix, @{user_share_dirs}/Steam/config/widevine/linux-x64/libwidevinecdm.so mr, @{user_share_dirs}/Steam/steamapps/common/SteamLinuxRuntime_soldier/*entry-point rpx, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/*.so* mr, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/*driverquery rix, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/fossilize_replay rPx, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/gameoverlayui rpx, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/panorama/** rm, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/reaper rpx, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/steam rix, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/steam-runtime-heavy.sh rix, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/steam-runtime{,-heavy}/{amd64,i386}/usr/bin/* rix, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/steam-runtime{,-heavy}/{setup,run}.sh rix, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/steam-runtime/{usr/,}lib{exec,}/** mr, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/steamwebhelper rix, @{user_share_dirs}/Steam/ubuntu[0-9]*_{32,64}/steamwebhelper.sh rix, /usr/share/fonts/**.{ttf,otf} rk, /usr/share/terminfo/x/xterm-256color r, /usr/share/themes/{,**} r, /usr/share/X11/{,**} r, /usr/share/zenity/* r, /etc/lsb-release r, /etc/udev/udev.conf r, /etc/machine-id r, /var/lib/dbus/machine-id r, / r, /{usr/,}{local/,} r, /{usr/,}{local/,}share/ r, /{usr/,}lib{,32,64}/ r, /etc/ r, /home/ r, /run/ r, /usr/bin/ r, /var/ r, owner @{HOME}/ r, owner @{HOME}/.local/ r, owner @{HOME}/.steam/{,**} rw, owner @{HOME}/.steam/registry.vdf rwk, owner @{HOME}/.steampath rw, owner @{HOME}/.steampid rw, owner @{user_games_dirs}/{,**} rwkl, owner @{user_config_dirs}/ r, owner @{user_config_dirs}/autostart/ r, owner @{user_config_dirs}/cef_user_data/{,**} r, owner @{user_config_dirs}/unity3d/{,**} rwk, owner @{user_share_dirs}/ r, owner @{user_share_dirs}/applications/*.desktop w, owner @{user_share_dirs}/icons/hicolor/**/apps/steam*.png rw, owner @{user_share_dirs}/Steam/ rw, owner @{user_share_dirs}/Steam/** rwkl -> @{user_share_dirs}/Steam/**, owner @{user_share_dirs}/vulkan/implicit_layer.d/steam*.json rwk, owner @{run}/user/@{uid}/.mutter-Xwaylandauth.[0-9A-Z]* rw, owner @{run}/user/@{uid}/gdm/Xauthority r, owner /dev/shm/#[0-9]* rw, owner /dev/shm/fossilize-*-[0-9]*-[0-9]* rw, owner /dev/shm/u@{uid}-Shm_@{hex} rw, owner /dev/shm/u@{uid}-ValveIPCSharedObj-Steam rwk, owner /dev/shm/ValveIPCSHM_@{uid} rw, owner /tmp/dumps/ rw, owner /tmp/dumps/{assert,crash}_[0-9]*_[0-9]*.dmp rw, owner /tmp/gdkpixbuf-xpm-tmp.[0-9A-Z]* rw, owner /tmp/miles_image_* mrw, owner /tmp/runtime-info.txt.* rwk, owner /tmp/sh-thd.* rw, owner /tmp/steam_chrome_shmem_uid@{uid}_spid[0-9]* rw, @{run}/udev/data/+input* r, # for mouse, keyboard, touchpad @{run}/udev/data/+sound* r, @{run}/udev/data/+pci* r, @{run}/udev/data/c13:[0-9]* r, # for /dev/input/* @{run}/udev/data/c116:[0-9]* r, # for ALSA @{run}/udev/data/c23[4-9]:[0-9]* r, # For dynamic assignment range 234 to 254 @{run}/udev/data/c24[0-9]:[0-9]* r, @{run}/udev/data/c25[0-4]:[0-9]* r, @{run}/udev/data/n[0-9]* r, @{sys}/ r, @{sys}/bus/ r, @{sys}/bus/pci/devices/ r, @{sys}/class/ r, @{sys}/class/hidraw/ r, @{sys}/class/input/ r, @{sys}/class/net/ r, @{sys}/class/sound/ r, @{sys}/devices/**/input[0-9]*/ r, @{sys}/devices/**/input[0-9]*/capabilities/* r, @{sys}/devices/**/input/input[0-9]*/ r, @{sys}/devices/**/uevent r, @{sys}/devices/pci[0-9]*/**/class r, @{sys}/devices/pci[0-9]*/**/i2c-[0-9]*/report_descriptor r, @{sys}/devices/pci[0-9]*/**/sound/card[0-9]*/** r, @{sys}/devices/pci[0-9]*/**/usb[0-9]*/{manufacturer,product,bcdDevice,bInterfaceNumber} r, @{sys}/devices/system/cpu/** r, @{sys}/devices/system/node/ r, @{sys}/devices/virtual/dmi/id/board_{vendor,name,version} rk, @{sys}/devices/virtual/dmi/id/product_{name,version} r, @{sys}/devices/virtual/dmi/id/sys_vendor r, @{sys}/devices/virtual/net/*/ r, @{sys}/devices/virtual/tty/tty[0-9]/active r, @{sys}/kernel/ r, @{sys}/power/suspend_stats/success rk, @{PROC}/ r, @{PROC}/@{pids}/comm rk, @{PROC}/@{pids}/net/route r, @{PROC}/@{pids}/stat r, @{PROC}/1/cgroup r, @{PROC}/sys/fs/inotify/max_user_watches r, @{PROC}/sys/kernel/sched_autogroup_enabled r, @{PROC}/sys/kernel/unprivileged_userns_clone r, @{PROC}/sys/kernel/yama/ptrace_scope r, @{PROC}/sys/user/max_user_namespaces r, @{PROC}/version r, owner @{PROC}/@{pid}/autogroup rw, owner @{PROC}/@{pid}/cmdline rk, owner @{PROC}/@{pid}/environ r, owner @{PROC}/@{pid}/fd/ r, owner @{PROC}/@{pid}/mounts r, owner @{PROC}/@{pid}/oom_score_adj w, owner @{PROC}/@{pid}/statm r, owner @{PROC}/@{pid}/task/ r, owner @{PROC}/@{pid}/task/@{tid}/comm rw, owner @{PROC}/@{pid}/task/@{tid}/status r, /dev/hidraw[0-9]* rw, /dev/input/ r, /dev/input/event[0-9]* r, /dev/tty rw, /dev/uinput w, /dev/video[0-9]* rw, audit deny /**.steam_exec_test.sh rw, deny owner @{user_share_dirs}/gvfs-metadata/{,*} r, profile lspci { include include include /{usr/,}bin/lspci mr, owner @{HOME}/.steam/steam.pipe r, @{sys}/bus/pci/devices/ r, @{sys}/bus/pci/slots/ r, @{sys}/bus/pci/slots/[0-9]*/address r, @{sys}/devices/pci[0-9]*/** r, owner /dev/shm/ValveIPCSHM_@{uid} rw, include if exists } include if exists }