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

abi <abi/4.0>,

include <tunables/global>

@{exec_path} = @{bin}/partprobe
profile partprobe /{,usr/}{,s}bin/partprobe flags=(complain) {
  include <abstractions/base>
  include <abstractions/disks-write>

  # To remove the following errors:
  #  device-mapper: version ioctl on   failed: Permission denied
  #  Incompatible libdevmapper 1.02.167 (2019-11-30) and kernel driver (unknown version).
  capability sys_admin,

  # To remove the following errors:
  #  kernel: device-mapper: core: partprobe: sending ioctl 1261 to DM device without required
  #  privilege.
  capability sys_rawio,

  # Needed?
  ptrace (read),

  @{exec_path} mr,

  @{sh_path}        rix,

  @{bin}/udevadm    rCx -> udevadm,

  @{bin}/dmidecode rPx,

  owner @{PROC}/@{pid}/mounts r,
        @{PROC}/swaps r,
        @{PROC}/devices r,

  /dev/mapper/ r,
  /dev/mapper/control rw,


  profile udevadm flags=(complain) {
    include <abstractions/base>

    ptrace (read),

    @{bin}/udevadm mr,

    /etc/udev/udev.conf r,

    owner @{PROC}/@{pid}/stat r,
    owner @{PROC}/@{pid}/cgroup r,
          @{PROC}/cmdline r,
          @{PROC}/1/sched r,
          @{PROC}/1/environ r,
          @{PROC}/1/cgroup r,
          @{PROC}/sys/kernel/osrelease r,
          @{PROC}/sys/kernel/random/boot_id r,

    # file_inherit
    include <abstractions/disks-write>  # lots of files in this abstraction get inherited
    /dev/mapper/control rw,

  }

  include if exists <local/partprobe>
}
