# 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} = @{sbin}/grub-install
@{att} = ""
profile grub-install /{,usr/}{,s}bin/grub-install flags=(complain) {
  include <abstractions/base-strict>
  include <abstractions/consoles>
  include <abstractions/disks-read>

  capability dac_read_search,
  capability sys_admin,

  @{exec_path} mr,

  @{sh_path}               rix,
  @{sbin}/efibootmgr       rix,
  @{bin}/kmod              rpx,
  @{bin}/lsb_release       rpx,
  @{bin}/udevadm           rpx,

  /usr/share/grub/{,**} r,
  /usr/share/locale-langpack/{,**} r,

  /etc/default/grub.d/{,**} r,
  /etc/default/grub r,

  @{efi}/ r,
  @{efi}/EFI/ r,
  @{efi}/EFI/*/grubx*.efi rw,
  @{efi}/EFI/BOOT/{,**} rw,
  @{efi}/EFI/ubuntu/* w,
  @{efi}/grub/{,**} rw,

  @{sys}/devices/**/hid r,
  @{sys}/devices/**/path r,
  @{sys}/devices/**/uid r,
  @{sys}/firmware/efi/ r,
  @{sys}/firmware/efi/efivars/ r,
  @{sys}/firmware/efi/efivars/Boot@{hex}-@{uuid} rw,
  @{sys}/firmware/efi/efivars/BootCurrent-@{uuid} r,
  @{sys}/firmware/efi/efivars/BootOrder-@{uuid} rw,
  @{sys}/firmware/efi/efivars/Timeout-@{uuid} r,
  @{sys}/firmware/efi/fw_platform_size r,
  @{sys}/firmware/efi/w_platform_size r,

        @{PROC}/devices r,
  owner @{PROC}/@{pid}/mountinfo r,

  /dev/mapper/control rw,

  include if exists <local/grub-install>
}


# vim:syntax=apparmor
