3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

WSL2でKeepassXCのSSH key-agentを利用する

Last updated at Posted at 2021-08-20

前置き

みなさん!WSL2でssh-agentはお使いでしょうか?

久しぶりにWindowsを使い始めたところでハマったのがssh-agentどうするんだ?問題でした。

MacOSの場合はkeepassXCがそのままssh-agentと同じように動作するので安全にssh-keyを管理できて便利だったのですが、windowsのkeepassXCはPageantとして動作するだけなのでWSL2環境のOpenSSHでは通信が不可能なのですよね。。

というわけで解決策をまとめてくれた以下の記事の適当翻訳を載せておきます。

KeepassXCを使用してSSHキーをWSL2とUbuntuに提供する方法

KeepassXCを使用してSSHキーをWSL2に提供できます。これは、サーバーにリモート接続する場合や、Git overSSHを使用する場合に便利です。SSHキーをKeepassXCに入れることのいくつかの利点は、秘密キーに強力なパスワードを設定できるが、毎回入力する必要がないことと、キーをディスクに保存する必要がないことです。 KeePassXCにキーの保存、ロック解除、提供を管理させます。

手順をスキップして、セットアップスクリプトに直接進むこともできます

KeePassXCを設定する

KeePassXCの設定を開き、そしてに選択Enable SSH AgentしてもUse OpenSSH for Windows instead of Pageant。
2番目のオプションでは、WindowsのOpenSSHサービスがすでに実行されている必要があります。実行されていない場合は、エラーメッセージが表示されます。

image.png

SSHキーを保存する

データベースに新しいエントリを作成し、名前を付けて、パスワードフィールドにSSHキーのパスフレーズを入力します。

詳細セクションで、公開鍵と秘密鍵を添付し、[OK]をクリックして、エントリを保存します。SSHエージェントが次のステップでキーを読み取れるように保存する必要があります。

次に、エントリを再度開き、[SSHエージェント]セクションの[秘密鍵]で、前に添付したファイルを選択します。セクションの残りの部分には、キーに関する詳細を入力する必要があります。もう一度[OK]をクリックして保存します。KeePassXCは現在、これらのキーをWindowsSSHエージェントに提供しています。

image.png
image.png
image.png

Npiperelayを入手する

npiperelayを使用すると、名前付きパイプがWSLのLinuxとWindowsの間で通信できるようになります。これはWindowsベースのツールですが、WSL2内から実行することも可能であるため、セットアップが便利です。

WSL2で、npiperelayバイナリをダウンロードして抽出します。

cd ~
wget https://github.com/jstarks/npiperelay/releases/latest/download/npiperelay_windows_amd64.zip
unzip npiperelay_windows_amd64.zip -d npiperelay
rm npiperelay_windows_amd64.zip

これにより、npiperelay.exeがになり/home/username/npiperelayます。

npiperelayをWindows側にダウンロードして、以下の対応するパスを次のようなスラッシュ表記に置き換えることもできます。/c/Temp/npiperelay.exe

socatをインストールします

WSL2にsocatをインストールして、npiperelayとの通信を許可します。

sudo apt install socat

WSLに使用するように指示します

WSL2にsocat経由でnpiperelayと通信するように指示する必要があります。これにより、Windows SSH Agentと通信できるようになり、KeePassXCからキーを取得できるようになります。

あなたには ~/.bashrc 、以下の行を追加します。このコードは、エージェントソケットが起動しているかどうかを確認します。

~/.bashrc
export SSH_AUTH_SOCK=$HOME/.ssh/agent.sock

ss -a | grep -q $SSH_AUTH_SOCK
if [ $? -ne 0 ]; then
    rm -f $SSH_AUTH_SOCK
    (setsid socat UNIX-LISTEN:$SSH_AUTH_SOCK,fork EXEC:"$HOME/npiperelay/npiperelay.exe -ei -s //./pipe/openssh-ssh-agent",nofork &) >/dev/null 2>&1
fi

動作テスト

公開鍵をGithubにすでに追加していると仮定して、簡単なテストを行います。

$ ssh -T git@github.com
Hi mendhak! You've successfully authenticated, but GitHub does not provide shell access.

1つのスクリプトですべて一緒に

これをbashスクリプトに保存して実行します。への書き込みを含む上記のすべての手順を実行する必要があります

~/.bashrc
cd ~

echo "Get npiperelay"
wget https://github.com/jstarks/npiperelay/releases/latest/download/npiperelay_windows_amd64.zip
unzip -o npiperelay_windows_amd64.zip -d npiperelay
rm npiperelay_windows_amd64.zip

echo "Install socat"
sudo apt -y install socat

echo "Add to .bashrc"
cat << 'EOF' >> ~/.bashrc
export SSH_AUTH_SOCK=$HOME/.ssh/agent.sock

ss -a | grep -q $SSH_AUTH_SOCK
if [ $? -ne 0 ]; then
    rm -f $SSH_AUTH_SOCK
    (setsid socat UNIX-LISTEN:$SSH_AUTH_SOCK,fork EXEC:"$HOME/npiperelay/npiperelay.exe -ei -s //./pipe/openssh-ssh-agent",nofork &) >/dev/null 2>&1
fi
EOF

echo "Reload ~/.bashrc"
exec bash

echo "Done"
3
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?