84 lines
3.2 KiB
Text
84 lines
3.2 KiB
Text
# apparmor.d - Full set of apparmor profiles
|
|
# Copyright (C) 2017-2022 Mikhail Morfikov
|
|
# Copyright (C) 2021-2022 Alexandre Pujol <alexandre@pujol.io>
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
abi <abi/3.0>,
|
|
|
|
include <tunables/global>
|
|
|
|
@{exec_path} = /{usr/,}bin/gpg-agent
|
|
profile gpg-agent @{exec_path} {
|
|
include <abstractions/base>
|
|
include <abstractions/nameservice-strict>
|
|
|
|
signal (receive) peer=pinentry-*,
|
|
signal (receive) peer=scdaemon,
|
|
|
|
@{exec_path} mr,
|
|
|
|
/{usr/,}lib/gnupg/scdaemon rPx,
|
|
/{usr/,}bin/pinentry{,-*} rPx,
|
|
|
|
/usr/share/gnupg/* r,
|
|
|
|
owner @{HOME}/@{XDG_GPG_DIR}/ rw,
|
|
owner @{HOME}/@{XDG_GPG_DIR}/gpg-agent.conf r,
|
|
owner @{HOME}/@{XDG_GPG_DIR}/private-keys-v1.d/ rw,
|
|
owner @{HOME}/@{XDG_GPG_DIR}/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner @{HOME}/@{XDG_GPG_DIR}/{,d.*/}S.gpg-agent{,.ssh,.browser,.extra} rw,
|
|
owner @{HOME}/@{XDG_GPG_DIR}/sshcontrol r,
|
|
|
|
owner @{MOUNTS}/*{,/*}/@{XDG_GPG_DIR}/ rw,
|
|
owner @{MOUNTS}/*{,/*}/@{XDG_GPG_DIR}/gpg-agent.conf r,
|
|
owner @{MOUNTS}/*{,/*}/@{XDG_GPG_DIR}/private-keys-v1.d/ rw,
|
|
owner @{MOUNTS}/*{,/*}/@{XDG_GPG_DIR}/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner @{MOUNTS}/*{,/*}/@{XDG_GPG_DIR}/{,d.*/}S.gpg-agent{,.ssh,.browser,.extra} rw,
|
|
owner @{MOUNTS}/*{,/*}/@{XDG_GPG_DIR}/sshcontrol r,
|
|
|
|
owner @{HOME}/@{XDG_PROJECTS_DIR}/**/{.,}gnupg/ rw,
|
|
owner @{HOME}/@{XDG_PROJECTS_DIR}/**/{.,}gnupg/gpg-agent.conf r,
|
|
owner @{HOME}/@{XDG_PROJECTS_DIR}/**/{.,}gnupg/private-keys-v1.d/ rw,
|
|
owner @{HOME}/@{XDG_PROJECTS_DIR}/**/{.,}gnupg/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner @{HOME}/@{XDG_PROJECTS_DIR}/**/{.,}gnupg/{,d.*/}S.gpg-agent{,.ssh,.browser,.extra} rw,
|
|
owner @{HOME}/@{XDG_PROJECTS_DIR}/**/{.,}gnupg/sshcontrol r,
|
|
|
|
owner @{run}/user/@{uid}/gnupg/ rw,
|
|
owner @{run}/user/@{uid}/gnupg/gpg-agent.conf r,
|
|
owner @{run}/user/@{uid}/gnupg/private-keys-v1.d/ rw,
|
|
owner @{run}/user/@{uid}/gnupg/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner @{run}/user/@{uid}/gnupg/{,d.*/}S.gpg-agent{,.ssh,.browser,.extra} rw,
|
|
owner @{run}/user/@{uid}/gnupg/sshcontrol r,
|
|
|
|
owner @{user_tmp_dirs}/**/{.,}gnupg/ rw,
|
|
owner @{user_tmp_dirs}/**/{.,}gnupg/gpg-agent.conf r,
|
|
owner @{user_tmp_dirs}/**/{.,}gnupg/private-keys-v1.d/ rw,
|
|
owner @{user_tmp_dirs}/**/{.,}gnupg/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner @{user_tmp_dirs}/**/{.,}gnupg/{,d.*/}S.gpg-agent{,.ssh,.browser,.extra} rw,
|
|
owner @{user_tmp_dirs}/**/{.,}gnupg/sshcontrol r,
|
|
|
|
owner /var/lib/*/.gnupg/ rw,
|
|
owner /var/lib/*/.gnupg/private-keys-v1.d/ rw,
|
|
owner /var/lib/*/.gnupg/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner /var/lib/*/.gnupg/{,d.*/}S.gpg-agent{,.ssh,.browser,.extra} rw,
|
|
owner /var/lib/*/.gnupg/sshcontrol r,
|
|
|
|
owner /var/lib/*/gnupg/ rw,
|
|
owner /var/lib/*/gnupg/private-keys-v1.d/ rw,
|
|
owner /var/lib/*/gnupg/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner /var/lib/*/gnupg/{,d.*/}S.gpg-agent{,.ssh,.browser,.extra} rw,
|
|
owner /var/lib/*/gnupg/sshcontrol r,
|
|
|
|
owner /tmp/tmp.*/gnupg/ rw,
|
|
owner /tmp/tmp.*/gnupg/private-keys-v1.d/ rw,
|
|
owner /tmp/tmp.*/gnupg/private-keys-v1.d/[0-9A-F]*.key rw,
|
|
owner /tmp/tmp.*/gnupg/{,d.*/}S.gpg-agent rw,
|
|
owner /tmp/tmp.*/gnupg/sshcontrol r,
|
|
|
|
owner @{PROC}/@{pid}/fd/ r,
|
|
|
|
# Silencer
|
|
deny /{usr/,}bin/.gnupg/ w,
|
|
|
|
include if exists <local/gpg-agent>
|
|
}
|