通过 msmtp 运行时 awk 权限被拒绝

Ajn*_*ned 3 email bash awk gnupg msmtp

我正在使用gpg2awk与 msmtp 一起在 emacs 中发送电子邮件。这是我.msmtprc文件的相关部分

account gmail
host smtp.gmail.com
from myusername@gmail.com
auth on
port 465
user myusername@gmail.com
passwordeval gpg2 -q --for-your-eyes-only --no-tty -d ~/.authinfo.gpg | awk '/machine smtp.gmail.com login myusername@gmail.com/ {print $NF}'
Run Code Online (Sandbox Code Playgroud)

这就是我的 .authinfo.gpg 文件的样子

machine smtp.gmail.com login myusername@gmail.com port 465 password myverysecretpassword
machine imap.gmail.com login myusername@gmail.com port 993 password myverysecretpassword
Run Code Online (Sandbox Code Playgroud)

出于某种原因,上述 passwordeval 字段中的命令在终端中运行良好,即它输出密码,但是当我使用 msmtp 运行它时

echo -e "Subject: Test Mail\r\n\r\nThis is a test mail" |msmtp --debug --from=default -t myusername@gmail.com
Run Code Online (Sandbox Code Playgroud)

awk 返回权限错误。

loaded user configuration file /home/myusername/.msmtprc
falling back to default account
sh: 1: awk: Permission denied
msmtp: cannot read output of 'gpg2 -q --for-your-eyes-only --no-tty -d ~/.authinfo.gpg | awk '/machine smtp.gmail.com login myusername@gmail.com/ {print $NF}''
Run Code Online (Sandbox Code Playgroud)

我完全不知道这里可能有什么问题。操作系统升级后出现此问题。我也在 .msmtprc 文件上运行了 chmod 600。任何帮助是极大的赞赏。

其他信息

  • 我试过暂时使用普通密码,它的工作原理
  • 我试图暂时授予 .msmtprc 777 权限,但没有奏效
  • 我试过重新安装msmtp,但没有用
  • 我尝试使用sed而不是,但awk我得到了相同的权限错误(对于 sed)。
  • 另一个帖子可能与此有关?它有点暗示 .msmtprc 所有者可能是相关的。就我而言,我是文件的所有者。

使用的版本

GNU Awk 5.0.1, API: 2.0 (GNU MPFR 4.0.2, GNU MP 6.2.0) 版权所有 (C) 1989, 1991-2019 自由软件基金会。

gpg (GnuPG) 2.2.19 libgcrypt 1.8.5 版权所有 (C) 2019 Free Software Foundation, Inc.

msmtp 版本 1.8.6 平台:x86_64-pc-linux-gnu TLS/SSL 库:GnuTLS

Ajn*_*ned 7

感谢 marlam 的建议,我发现这个问题是由于 msmtp 的 AppArmor 配置文件过于严格。我认为我的新操作系统版本对 msmtp 的使用更加严格(我猜是好事)。不幸的是,这经常发生在 Debian 和 Ubuntu 上,它让许多用户感到困惑。我用来解决它的命令是

sudo ln -s /etc/apparmor.d/usr.bin.msmtp /etc/apparmor.d/disable/
sudo apparmor_parser -R /etc/apparmor.d/usr.bin.msmtp 
Run Code Online (Sandbox Code Playgroud)