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

abi <abi/4.0>,

include <tunables/global>

@{exec_path} = @{bin}/ddcutil
@{att} = ""
profile ddcutil /{,usr/}bin/ddcutil flags=(complain) {
  include <abstractions/base-strict>
  include <abstractions/consoles>
  include <abstractions/dri>
  include <abstractions/nameservice-strict>

  capability sys_admin,

  @{exec_path} mr,

  @{sh_path}               rix,
  @{bin}/find              rix,
  @{bin}/sed               rix,
  @{bin}/xargs             rix,
  @{bin}/{,e}grep          rix,

  / r,

  owner @{user_cache_dirs}/ddcutil/ rw,
  owner @{user_cache_dirs}/ddcutil/** rwlk,

  @{run}/udev/data/+*:* r,                # Identifies all subsystems
  @{run}/udev/data/c@{int}:@{int} r,      # Identifies all character devices

  @{sys}/ r,
  @{sys}/bus/ r,
  @{sys}/bus/** r,
  @{sys}/class/ r,
  @{sys}/class/** r,
  @{sys}/devices/ r,
  @{sys}/devices/** r,

  owner @{PROC}/@{pid}/fd/ r,

  /dev/ r,
  /dev/i2c-@{int} rwk,

  include if exists <local/ddcutil>
}

# vim:syntax=apparmor
