# apparmor.d - Full set of apparmor profiles
# Copyright (C) 2019-2021 Mikhail Morfikov
# 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} = @{sbin}/mkfs.btrfs
@{att} = ""
profile mkfs-btrfs /{,usr/}{,s}bin/mkfs.btrfs flags=(complain) {
  include <abstractions/base-strict>
  include <abstractions/disks-write>

  capability sys_admin,
  capability sys_rawio,

  @{exec_path} mr,

  /dev/btrfs-control rw,

  # A place for file images
  owner @{user_img_dirs}/{,**} rwk,

  @{run}/blkid/blkid.* rw,

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

  include if exists <local/mkfs-btrfs>
}

# vim:syntax=apparmor
