# 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} = @{bin}/ksmserver
profile ksmserver /{,usr/}{,s}bin/ksmserver  flags=(attach_disconnected,mediate_deleted,complain) {
  include <abstractions/base>
  include <abstractions/bus/org.freedesktop.login1.Session>
  include <abstractions/app-launcher-user>
  include <abstractions/graphics>
  include <abstractions/kde-strict>
  include <abstractions/nameservice-strict>

  signal (send) set=(usr1,term) peer=kscreenlocker-greet,

  unix (send, receive) type=stream peer=(label="kscreenlocker-greet",addr=none),

  @{exec_path} mr,

  @{bin}/rm            rix,
  @{thunderbird_path}  rPx,

  @{lib}/@{multiarch}/{,libexec/}DiscoverNotifier Px,
  @{lib}/DiscoverNotifier Px,
  @{lib}/@{multiarch}/{,libexec/}drkonqi Px,
  @{lib}/drkonqi Px,
  @{lib}/@{multiarch}/{,libexec/}kscreenlocker_greet Px,
  @{lib}/kscreenlocker_greet Px,

  @{user_bin_dirs}/** rPUx,

  /usr/share/color-schemes/{,**} r,
  /usr/share/knotifications{5,6}/*.notifyrc r,
  /usr/share/kservices{5,6}/{,**} r,
  /usr/share/kservicetypes{5,6}/{,**} r,

  /etc/xdg/menus/applications-merged/ r,
  /etc/machine-id r,
  /etc/xdg/kscreenlockerrc r,
  /etc/xdg/menus/ r,

  /var/lib/flatpak/exports/share/mime/ r,

  owner @{HOME}/@{rand6} rw,
  owner @{HOME}/.Xauthority rw,

  owner @{user_cache_dirs}/#@{int} rw,
  owner @{user_cache_dirs}/fontconfig/*-le64.cache-* r,
  owner @{user_cache_dirs}/icon-cache.kcache rw,
  owner @{user_cache_dirs}/ksycoca{5,6}_* rwlk,

  owner @{user_config_dirs}/#@{int} rw,
  owner @{user_config_dirs}/kscreenlockerrc r,
  owner @{user_config_dirs}/ksmserverrc rw,
  owner @{user_config_dirs}/ksmserverrc.@{rand6} rwl,
  owner @{user_config_dirs}/ksmserverrc.lock rwk,
  owner @{user_config_dirs}/menus/ r,
  # owner @{user_config_dirs}/session/*_[0-9]*_[0-9]*_[0-9]* rw,

  owner @{user_share_dirs}/kservices{5,6}/ r,
  owner @{user_share_dirs}/kservices{5,6}/ServiceMenus/ r,

  owner /tmp/@{rand6} rw,

        @{run}/systemd/inhibit/[0-9]*.ref rw,
  owner @{run}/user/@{uid}/KSMserver__[0-9] rw,

  @{PROC}/sys/kernel/core_pattern r,

  /dev/tty r,

  include if exists <local/ksmserver>
}
