# apparmor.d - Full set of apparmor profiles
# Copyright (C) 2022-2024 Alexandre Pujol <alexandre@pujol.io>
# Copyright (C) 2022 Jeroen Rijken
# SPDX-License-Identifier: GPL-2.0-only

abi <abi/4.0>,

include <tunables/global>

@{exec_path} = @{bin}/grub-probe
profile grub-probe /{,usr/}{,s}bin/grub-probe flags=(complain) {
  include <abstractions/base>
  include <abstractions/consoles>
  include <abstractions/disks-read>

  capability dac_read_search,
  capability sys_admin,

  @{exec_path} mr,

  /{usr/,}{local/,}{s,}bin/zpool rpx,
  @{bin}/lsb_release        rpx -> lsb_release,
  @{bin}/lvm                rpx,
  @{bin}/udevadm            rpx,

  /usr/share/grub/* r,

  / r,
  /boot/ r,
  /boot/grub/themes/{,**} r,

  @{PROC}/@{pids}/mountinfo r,
  @{PROC}/devices r,

  /dev/*vg*/ r,
  /dev/bsg/ r,
  /dev/bus/ r,
  /dev/bus/usb/ r,
  /dev/bus/usb/@{int}/ r,
  /dev/char/ r,
  /dev/cpu/ r,
  /dev/cpu/@{int}/ r,
  /dev/dma_heap/ r,
  /dev/dri/ r,
  /dev/dri/by-path/ r,
  /dev/hugepages/ r,
  /dev/input/ r,
  /dev/input/by-id/ r,
  /dev/input/by-path/ r,
  /dev/mapper/control rw,
  /dev/mqueue/ r,
  /dev/shm/ r,
  /dev/snd/ r,
  /dev/snd/by-path/ r,

  include if exists <local/grub-probe>
}

# vim:syntax=apparmor
