gpt4 book ai didi

git - Emacs + GPG + pinentry.el 进行身份验证

转载 作者:行者123 更新时间:2023-12-04 02:37:49 41 4
gpt4 key购买 nike

我很难设置 pinentry让 Emacs 与身份验证一起工作(比如 github)。使用 GPG 和 pinentry 来签署提交已经有效。我在 emacs 中使用 magit 进行版本控制,每次我在迷你缓冲区中 pop pinentry 时,我输入我的密码并签署提交。一切顺利。

但是我也使用 GPG 进行身份验证。我 setup和带有 GPG 的身份验证子 key ,并设置 SSH 以使用它。如果我从 tty 执行此操作,它也能正常工作。只是不是来自 Emacs 内部。该问题与 $GPG_TTY 环境变量有关。如果我尝试将某些内容推送到 GH,则不会 pop 迷你缓冲区中的 pinentry。相反,它等待并最终说我没有许可。

我应该提到我使用 emacs,更具体地说,EXWM 作为我的窗口管理器。如果我随后退出 emacs,我会在我的 TTY 中看到 pinentry-encurses 对话框。如果我在推送时在 emacs 中打开了另一个终端,它将在该终端中打开 pinentry-ncurses 对话框,而不是在迷你缓冲区中 pop pinentry.el。

几天来我一直在谷歌上搜索并尝试不同的方法,但没有成功。

~/.gnupg/gpg-agent.conf:

allow-emacs-pinentry
allow-loopback-pinentry
default-cache-ttl 600
max-cache-ttl 7200
enable-ssh-support

~/.gnupg/gpg.conf:

use-agent

~/.bash_profile:

# GPG related
export SSH_AUTH_SOCK=$(gpgconf --list-dirs agent-ssh-socket)
export GPG_TTY=$(tty)
#gpgconf --launch gpg-agent

我在 emacs 中的 pinentry 配置:

;; Enable loopback so that pinentry will pop up in emacs
(setq epa-pinentry-mode 'loopback)
(pinentry-start)

;; Update the TTY for gpg-agent
;(setenv "GPG_TTY" "/dev/pts/0")
(shell-command "gpgconf --launch-agent")
(shell-command "gpg-connect-agent updatestartuptty /bye >/dev/null")

我尝试在 emacs 中手动设置 $GPG_TTY,如您所见,但没有成功。令我感到困惑的是,它只适用于签署提交但不适用于身份验证。

最佳答案

好久没问这个问题了。直到我停止玩这个游戏一段时间并在几周后回来时,我才找到答案。不幸的是,我无法说出为什么它首先不起作用。但是我发现了一个恰好适合我的配置,自从我发现我没有触及任何文件后,它就是:

要求:

  • Emacs 27+(我没有测试过旧版本)
  • pinentry-emacs。如果您的包管理器中不可用,请从源代码构建它:
# Install deps (these also include emacs deps - sorry)
sudo apt update && sudo apt install -y git libgpg-error-dev libassuan-dev lbzip2 autoconf automake autotools-dev bsd-mailx build-essential diffstat gnutls-dev imagemagick libasound2-dev libc6-dev libdatrie-dev libdbus-1-dev libgconf2-dev libgif-dev libgnutls28-dev libgpm-dev libgtk2.0-dev libgtk-3-dev libice-dev libjpeg-dev liblockfile-dev liblqr-1-0 libm17n-dev libmagickwand-dev libncurses5-dev libncurses-dev libotf-dev libpng-dev librsvg2-dev libsm-dev libthai-dev libtiff5-dev libtiff-dev libtinfo-dev libtool libx11-dev libxext-dev libxi-dev libxml2-dev libxmu-dev libxmuu-dev libxpm-dev libxrandr-dev libxt-dev libxtst-dev libxv-dev quilt sharutils texinfo xaw3dg xaw3dg-dev xorg-dev xutils-dev zlib1g-dev libjansson-dev libxaw7-dev libselinux1-dev libmagick++-dev libacl1-dev

# build pinentry-emacs
cd ~
wget https://gnupg.org/ftp/gcrypt/pinentry/pinentry-1.1.0.tar.bz2
tar -xf pinentry-1.1.0.tar.bz2
cd pinentry-1.1.0
./configure --enable-pinentry-emacs --enable-inside-emacs
make
sudo make install
cd ~
rm -rf pinentry-1.1.0 pinentry-1.1.0.tar.bz2

现在是配置文件:

# set this somwhere in your .bashrc / .zshrc / ...
export SSH_AUTH_SOCK=$(gpgconf --list-dirs agent-ssh-socket)

~/.gnupg/gpg-agent.conf:

pinentry-program /usr/local/bin/pinentry-emacs # or we the path is
enable-ssh-support

~/.gnupg/sshcontrol:

<keygrip of your auth key>

使用gpg2 --list-secret-keys --keyid-format LONG --with-keygrip获取keygrip。

现在是 emacs 本身。安装pinentry对于 emacs。我使用 doom,所以我只需要执行 (package!pinentry)

应用以下配置:

;; Enable loopback so that pinentry will pop up in emacs
(pinentry-start)

;; Start GPG agent with SSH support
(shell-command "gpg-connect-agent /bye")

至少对我来说,在完成所有这些之后,emacs 中的 pinentry 可以同时用于签名和身份验证。

关于git - Emacs + GPG + pinentry.el 进行身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60812866/

41 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com