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

abi <abi/4.0>,

include <tunables/global>

@{exec_path} = @{sbin}/e2fsck @{sbin}/fsck.ext2 @{sbin}/fsck.ext3 @{sbin}/fsck.ext4
@{att} = ""
profile e2fsck /{{,usr/}{,s}bin/e2fsck,{,usr/}{,s}bin/fsck.ext2,{,usr/}{,s}bin/fsck.ext3,{,usr/}{,s}bin/fsck.ext4} flags=(complain) {
  include <abstractions/base-strict>
  include <abstractions/consoles>
  include <abstractions/disks-write>
  include <abstractions/user-download-strict>

  capability dac_read_search,
  capability sys_rawio,

  @{exec_path} mr,

  # To check for badblocks
  @{sh_path}        rix,
  @{sbin}/badblocks rpx,

  /usr/share/file/misc/magic.mgc r,

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

        @{run}/blkid/ rw,
        @{run}/systemd/fsck.progress rw,
  owner @{run}/blkid/blkid.tab.old rwl -> @{run}/blkid/blkid.tab,
  owner @{run}/blkid/blkid.tab{,-@{rand6}} rw,

  @{sys}/devices/**/power_supply/AC/online r,

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

  include if exists <local/e2fsck>
}

# vim:syntax=apparmor
