# apparmor.d - Full set of apparmor profiles
# 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} = /usr/share/libalpm/scripts/mkinitcpio
@{att} = /att/pacman-hook-mkinitcpio/
profile pacman-hook-mkinitcpio /usr/share/libalpm/scripts/mkinitcpio  flags=(attach_disconnected,attach_disconnected.path=@{att},complain) {
  include <abstractions/attached/base>
  include <abstractions/nameservice-strict>

  capability dac_read_search,
  capability mknod,

  @{exec_path} mr,

  @{sh_path}        rix,
  @{bin}/cmp        rix,
  @{bin}/compgen    rix,
  @{bin}/env        rix,
  @{bin}/install    rix,
  @{bin}/mkinitcpio rpx,
  @{bin}/mv         rix,
  @{bin}/od         rix,
  @{bin}/rm         rix,
  @{bin}/sed        rix,
  @{bin}/sort       rix,
  @{bin}/stat       rix,
  @{bin}/pacman     rcx -> pacman,

  /usr/share/mkinitcpio/*.preset r,

  /etc/mkinitcpio.d/{,**} r,
  /etc/mkinitcpio.d/*.preset{,.pacsave} rw,

  / r,
  @{efi}/ r,
  @{efi}/EFI/boot/boot*.efi rw,
  @{efi}/initramfs-*-fallback.img rw,
  @{efi}/initramfs-*.img rw,
  @{efi}/vmlinuz-* rw,

  /dev/tty rw,
  owner /dev/pts/@{int} rw,

  # # Inherit Silencer
  deny network inet6 stream,
  deny network inet stream,

  profile pacman flags=(attach_disconnected,attach_disconnected.path=@{att},complain) {
    include <abstractions/attached/base>

    capability dac_read_search,

    @{bin}/pacman mr,

    @{bin}/gpg rix,
    @{bin}/gpgconf rix,
    @{bin}/gpgsm rix,

    /etc/pacman.conf r,
    /etc/pacman.d/{,**} r,
    /etc/pacman.d/gnupg/** rwkl,

    /var/lib/pacman/{,**} r,

    @{HOME}/@{XDG_GPG_DIR}/*.conf r,

    include if exists <local/pacman-hook-mkinitcpio_pacman>
  }

  include if exists <local/pacman-hook-mkinitcpio>
}

# vim:syntax=apparmor
