apparmor: Add user session path for PID and socket files used by passt

Commit 7a39b04d68 ("apparmor: Enable passt support") grants
passt(1) read-write access to /{,var/}run/libvirt/qemu/passt/* if
started by the libvirt daemon. That's the path where passt creates
PID and socket files only if the guest is started by the root user.

If the guest is started by another user, though, the path is more
commonly /var/run/user/$UID/libvirt/qemu/run/passt: add it as
read-write location. Otherwise, passt won't be able to start, as
reported by Andreas.

While at it, replace /{,var/}run/ in the existing rule by its
corresponding tunable variable, @{run}.

Fixes: 7a39b04d68 ("apparmor: Enable passt support")
Link: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1061678
Reported-by: Andreas B. Mundt <andi@debian.org>
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
Reviewed-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Jim Fehlig <jfehlig@suse.com>
This commit is contained in:
Stefano Brivio 2024-01-30 19:15:51 +01:00 committed by Andrea Bolognani
parent 7284b4cf8b
commit f95675fdbb

View File

@ -196,7 +196,8 @@
signal (receive) set=("term") peer=libvirtd, signal (receive) set=("term") peer=libvirtd,
signal (receive) set=("term") peer=virtqemud, signal (receive) set=("term") peer=virtqemud,
owner /{,var/}run/libvirt/qemu/passt/* rw, owner @{run}/user/[0-9]*/libvirt/qemu/run/passt/* rw,
owner @{run}/libvirt/qemu/passt/* rw,
include if exists <abstractions/passt> include if exists <abstractions/passt>
} }