mirror of
https://github.com/roddhjav/apparmor.d.git
synced 2025-01-18 08:58:15 +01:00
feat(profiles): better cockpit integration.
This commit is contained in:
parent
558cb68f23
commit
5e77974546
10 changed files with 75 additions and 1 deletions
|
@ -21,6 +21,7 @@ profile cockpit-bridge @{exec_path} {
|
||||||
network inet6 dgram,
|
network inet6 dgram,
|
||||||
network inet6 stream,
|
network inet6 stream,
|
||||||
|
|
||||||
|
signal (send) set=term peer=cockpit-pcp,
|
||||||
signal (send) set=term peer=dbus-daemon,
|
signal (send) set=term peer=dbus-daemon,
|
||||||
signal (send) set=term peer=ssh-agent,
|
signal (send) set=term peer=ssh-agent,
|
||||||
signal (send) set=term peer=sudo,
|
signal (send) set=term peer=sudo,
|
||||||
|
@ -29,6 +30,8 @@ profile cockpit-bridge @{exec_path} {
|
||||||
@{exec_path} mr,
|
@{exec_path} mr,
|
||||||
|
|
||||||
/{usr/,}bin/journalctl rPx,
|
/{usr/,}bin/journalctl rPx,
|
||||||
|
/{usr/,}lib/cockpit/cockpit-pcp rPx,
|
||||||
|
/{usr/,}lib/cockpit/cockpit-ssh rPx,
|
||||||
|
|
||||||
/usr/share/cockpit/{,**} r,
|
/usr/share/cockpit/{,**} r,
|
||||||
|
|
||||||
|
|
|
@ -10,9 +10,17 @@ include <tunables/global>
|
||||||
profile cockpit-certificate-ensure @{exec_path} {
|
profile cockpit-certificate-ensure @{exec_path} {
|
||||||
include <abstractions/base>
|
include <abstractions/base>
|
||||||
|
|
||||||
|
capability dac_override,
|
||||||
|
capability dac_read_search,
|
||||||
|
capability chown,
|
||||||
|
|
||||||
@{exec_path} mr,
|
@{exec_path} mr,
|
||||||
|
|
||||||
|
/{usr/,}lib/cockpit/cockpit-certificate-helper rPx,
|
||||||
|
|
||||||
/etc/cockpit/ws-certs.d/{,*} r,
|
/etc/cockpit/ws-certs.d/{,*} r,
|
||||||
|
|
||||||
|
owner @{run}/cockpit/tls/server/{,**} rw,
|
||||||
|
|
||||||
include if exists <local/cockpit-certificate-ensure>
|
include if exists <local/cockpit-certificate-ensure>
|
||||||
}
|
}
|
|
@ -9,8 +9,23 @@ include <tunables/global>
|
||||||
@{exec_path} = /{usr/,}lib/cockpit/cockpit-certificate-helper
|
@{exec_path} = /{usr/,}lib/cockpit/cockpit-certificate-helper
|
||||||
profile cockpit-certificate-helper @{exec_path} {
|
profile cockpit-certificate-helper @{exec_path} {
|
||||||
include <abstractions/base>
|
include <abstractions/base>
|
||||||
|
include <abstractions/nameservice-strict>
|
||||||
|
|
||||||
@{exec_path} mr,
|
@{exec_path} mr,
|
||||||
|
|
||||||
|
/{usr/,}bin/{,ba,da}sh rix,
|
||||||
|
/{usr/,}bin/chmod rix,
|
||||||
|
/{usr/,}bin/id rix,
|
||||||
|
/{usr/,}bin/mkdir rix,
|
||||||
|
/{usr/,}bin/mv rix,
|
||||||
|
/{usr/,}bin/rm rix,
|
||||||
|
/{usr/,}bin/sscg rix,
|
||||||
|
/{usr/,}bin/tr rix,
|
||||||
|
|
||||||
|
/etc/machine-id r,
|
||||||
|
|
||||||
|
owner @{run}/cockpit/certificate-helper/{,**} rw,
|
||||||
|
|
||||||
include if exists <local/cockpit-certificate-helper>
|
include if exists <local/cockpit-certificate-helper>
|
||||||
|
|
||||||
}
|
}
|
33
apparmor.d/groups/virt/cockpit-pcp
Normal file
33
apparmor.d/groups/virt/cockpit-pcp
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
# apparmor.d - Full set of apparmor profiles
|
||||||
|
# Copyright (C) 2023 Alexandre Pujol <alexandre@pujol.io>
|
||||||
|
# SPDX-License-Identifier: GPL-2.0-only
|
||||||
|
|
||||||
|
abi <abi/3.0>,
|
||||||
|
|
||||||
|
include <tunables/global>
|
||||||
|
|
||||||
|
@{exec_path} = /{usr/,}lib/cockpit/cockpit-pcp
|
||||||
|
profile cockpit-pcp @{exec_path} {
|
||||||
|
include <abstractions/base>
|
||||||
|
include <abstractions/nameservice-strict>
|
||||||
|
include <abstractions/disks-read>
|
||||||
|
|
||||||
|
network inet6 dgram,
|
||||||
|
network inet6 stream,
|
||||||
|
|
||||||
|
signal (receive) peer=cockpit-bridge,
|
||||||
|
|
||||||
|
@{exec_path} mr,
|
||||||
|
|
||||||
|
/etc/pcp.conf r,
|
||||||
|
/etc/pcp/{,**} r,
|
||||||
|
|
||||||
|
/var/lib/pcp/{,**} rw,
|
||||||
|
|
||||||
|
@{PROC}/diskstats r,
|
||||||
|
@{PROC}/swaps r,
|
||||||
|
owner @{PROC}/@{pid}/mounts r,
|
||||||
|
@{PROC}/@{pid}/net/dev r,
|
||||||
|
|
||||||
|
include if exists <local/cockpit-pcp>
|
||||||
|
}
|
|
@ -9,8 +9,10 @@ include <tunables/global>
|
||||||
@{exec_path} = /{usr/,}lib/cockpit/cockpit-session
|
@{exec_path} = /{usr/,}lib/cockpit/cockpit-session
|
||||||
profile cockpit-session @{exec_path} flags=(attach_disconnected) {
|
profile cockpit-session @{exec_path} flags=(attach_disconnected) {
|
||||||
include <abstractions/base>
|
include <abstractions/base>
|
||||||
include <abstractions/nameservice-strict>
|
|
||||||
include <abstractions/authentication>
|
include <abstractions/authentication>
|
||||||
|
include <abstractions/bash>
|
||||||
|
include <abstractions/nameservice-strict>
|
||||||
|
include <abstractions/zsh>
|
||||||
|
|
||||||
capability audit_write,
|
capability audit_write,
|
||||||
capability dac_read_search,
|
capability dac_read_search,
|
||||||
|
@ -24,16 +26,20 @@ profile cockpit-session @{exec_path} flags=(attach_disconnected) {
|
||||||
|
|
||||||
/{usr/,}bin/{,z,ba,da}sh rix,
|
/{usr/,}bin/{,z,ba,da}sh rix,
|
||||||
/{usr/,}bin/cockpit-bridge rPx,
|
/{usr/,}bin/cockpit-bridge rPx,
|
||||||
|
/{usr/,}lib/cockpit/cockpit-pcp rPx,
|
||||||
|
|
||||||
@{etc_ro}/environment r,
|
@{etc_ro}/environment r,
|
||||||
/etc/group r,
|
/etc/group r,
|
||||||
/etc/motd r,
|
/etc/motd r,
|
||||||
|
/etc/motd.d/ r,
|
||||||
@{etc_ro}/security/limits.d/{,*.conf} r,
|
@{etc_ro}/security/limits.d/{,*.conf} r,
|
||||||
/etc/shells r,
|
/etc/shells r,
|
||||||
|
|
||||||
@{run}/faillock/[a-zA-z0-9]* rwk,
|
@{run}/faillock/[a-zA-z0-9]* rwk,
|
||||||
@{run}/systemd/sessions/*.ref rw,
|
@{run}/systemd/sessions/*.ref rw,
|
||||||
@{run}/utmp rwk,
|
@{run}/utmp rwk,
|
||||||
|
@{run}/motd.d/{,*} r,
|
||||||
|
@{run}/cockpit/active.motd r,
|
||||||
|
|
||||||
/var/log/btmp rw,
|
/var/log/btmp rw,
|
||||||
/var/log/lastlog rw,
|
/var/log/lastlog rw,
|
||||||
|
@ -43,5 +49,7 @@ profile cockpit-session @{exec_path} flags=(attach_disconnected) {
|
||||||
owner @{PROC}/@{pid}/uid_map r,
|
owner @{PROC}/@{pid}/uid_map r,
|
||||||
@{PROC}/@{pids}/fd/ r,
|
@{PROC}/@{pids}/fd/ r,
|
||||||
|
|
||||||
|
/dev/tty rw,
|
||||||
|
|
||||||
include if exists <local/cockpit-session>
|
include if exists <local/cockpit-session>
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@ include <tunables/global>
|
||||||
@{exec_path} = /{usr/,}lib/cockpit/cockpit-ssh
|
@{exec_path} = /{usr/,}lib/cockpit/cockpit-ssh
|
||||||
profile cockpit-ssh @{exec_path} {
|
profile cockpit-ssh @{exec_path} {
|
||||||
include <abstractions/base>
|
include <abstractions/base>
|
||||||
|
include <abstractions/nameservice-strict>
|
||||||
|
|
||||||
@{exec_path} mr,
|
@{exec_path} mr,
|
||||||
|
|
||||||
|
|
|
@ -16,5 +16,7 @@ profile cockpit-tls @{exec_path} {
|
||||||
|
|
||||||
/etc/cockpit/ws-certs.d/{,**} r,
|
/etc/cockpit/ws-certs.d/{,**} r,
|
||||||
|
|
||||||
|
owner @{run}/cockpit/tls/{,**} rw,
|
||||||
|
|
||||||
include if exists <local/cockpit-tls>
|
include if exists <local/cockpit-tls>
|
||||||
}
|
}
|
|
@ -15,6 +15,7 @@ profile cockpit-ws @{exec_path} {
|
||||||
/{usr/,}lib/cockpit/cockpit-session rPx,
|
/{usr/,}lib/cockpit/cockpit-session rPx,
|
||||||
|
|
||||||
/usr/share/cockpit/{,**} r,
|
/usr/share/cockpit/{,**} r,
|
||||||
|
/usr/share/pixmaps/{,**} r,
|
||||||
/etc/cockpit/ws-certs.d/ r,
|
/etc/cockpit/ws-certs.d/ r,
|
||||||
|
|
||||||
owner @{PROC}/@{pid}/cgroup r,
|
owner @{PROC}/@{pid}/cgroup r,
|
||||||
|
|
|
@ -10,6 +10,8 @@ include <tunables/global>
|
||||||
profile cockpit-wsinstance-factory @{exec_path} {
|
profile cockpit-wsinstance-factory @{exec_path} {
|
||||||
include <abstractions/base>
|
include <abstractions/base>
|
||||||
|
|
||||||
|
capability net_admin,
|
||||||
|
|
||||||
@{exec_path} mr,
|
@{exec_path} mr,
|
||||||
|
|
||||||
include if exists <local/cockpit-wsinstance-factory>
|
include if exists <local/cockpit-wsinstance-factory>
|
||||||
|
|
|
@ -21,6 +21,7 @@ profile libvirt-dbus @{exec_path} {
|
||||||
|
|
||||||
owner @{user_cache_dirs}/libvirt/libvirtd.lock rwk,
|
owner @{user_cache_dirs}/libvirt/libvirtd.lock rwk,
|
||||||
|
|
||||||
|
@{run}/user/@{uid}/libvirt/ rw,
|
||||||
@{run}/user/@{uid}/libvirt/libvirtd.lock rwk,
|
@{run}/user/@{uid}/libvirt/libvirtd.lock rwk,
|
||||||
@{run}/user/@{uid}/libvirt/virtqemud.lock rwk,
|
@{run}/user/@{uid}/libvirt/virtqemud.lock rwk,
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue