apparmor.d/apparmor.d/groups/virt/virtnetworkd

47 lines
1.2 KiB
Text

# apparmor.d - Full set of apparmor profiles
# 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} = @{bin}/virtnetworkd
profile virtnetworkd @{exec_path} flags=(attach_disconnected) {
include <abstractions/base>
include <abstractions/nameservice-strict>
network netlink raw,
ptrace (read) peer=virtqemud,
ptrace (read) peer=unconfined,
@{exec_path} mr,
@{sbin}/dnsmasq rPx,
/etc/libvirt/*.conf r,
owner /var/lib/libvirt/dnsmasq/*.macs* rw,
@{att}/@{run}/systemd/inhibit/@{int}.ref rw,
@{run}/libvirt/network/default.pid r,
@{run}/utmp rk,
owner @{run}/libvirt/common/system.token rwk,
owner @{run}/libvirt/network/{,**} rwk,
owner @{run}/user/@{uid}/libvirt/common/system.token rwk,
owner @{run}/user/@{uid}/libvirt/network/{,**} rwk,
owner @{run}/user/@{uid}/libvirt/virtnetworkd* rwk,
owner @{run}/virtnetworkd.pid w,
@{sys}/devices/system/node/ r,
@{sys}/devices/system/node/node@{int}/meminfo r,
owner @{PROC}/@{pid}/stat r,
owner @{PROC}/@{pids}/fd/ r,
include if exists <local/virtnetworkd>
}
# vim:syntax=apparmor