「GnuPG」の版間の差分
Kusanaginoturugi (トーク | 投稿記録) (→鍵を表示: 鍵を鍵の一覧に変更) |
細 (リンクを修正) |
||
(4人の利用者による、間の75版が非表示) | |||
1行目: | 1行目: | ||
[[Category:暗号化]] |
[[Category:暗号化]] |
||
+ | [[Category:メール]] |
||
+ | [[Category:GNU]] |
||
[[en:GnuPG]] |
[[en:GnuPG]] |
||
[[es:GnuPG]] |
[[es:GnuPG]] |
||
18行目: | 20行目: | ||
{{Pkg|gnupg}} をインストールしてください。 |
{{Pkg|gnupg}} をインストールしてください。 |
||
− | gnupg をインストールすると、GnuPG がパスフレーズエントリに使用するシンプルな PIN やパスフレーズエントリダイアログのコレクションである {{Pkg|pinentry}} もインストールされます。 |
+ | gnupg をインストールすると、GnuPG がパスフレーズエントリに使用するシンプルな PIN やパスフレーズエントリダイアログのコレクションである {{Pkg|pinentry}} もインストールされます。シェルスクリプト {{ic|/usr/bin/pinentry}} は [[#pinentry]] で説明されている順番で、どの ''pinentry'' ダイアログを使用するかを決定します。 |
グラフィカルフロントエンドや GnuPG と連携するプログラムを使いたい場合は[[アプリケーション一覧/セキュリティ#暗号化, 署名, ステガノグラフィー]]を参照してください。 |
グラフィカルフロントエンドや GnuPG と連携するプログラムを使いたい場合は[[アプリケーション一覧/セキュリティ#暗号化, 署名, ステガノグラフィー]]を参照してください。 |
||
71行目: | 73行目: | ||
{{Note|入力した名前とメールアドレスは鍵をインポートすれば誰でも確認できるようになります。}} |
{{Note|入力した名前とメールアドレスは鍵をインポートすれば誰でも確認できるようになります。}} |
||
− | === 鍵 |
+ | === 鍵一覧 === |
* 公開鍵束の鍵の一覧: |
* 公開鍵束の鍵の一覧: |
||
93行目: | 95行目: | ||
あるいは、[[#鍵サーバーを使用する|鍵サーバー]]で鍵を共有する方法もあります。 |
あるいは、[[#鍵サーバーを使用する|鍵サーバー]]で鍵を共有する方法もあります。 |
||
+ | {{Tip| |
||
− | {{Tip|{{ic|--no-emit-version}} を使うか、これを設定ファイルに書くことでバージョン番号の表示を抑制できます。}} |
||
+ | * {{ic|--no-emit-version}} を使うか、これを設定ファイルに書くことでバージョン番号の表示を抑制できます。 |
||
+ | * {{ic|user-id}} を省略して、キーリング内のすべての公開鍵をエクスポートできます。これは、一度に複数の ID を共有したい場合や、別のアプリケーションにインポートする場合に便利です。例: [[Thunderbird#Use_OpenPGP_with_external_GnuPG|Thunderbird]]。}} |
||
=== 公開鍵のインポート === |
=== 公開鍵のインポート === |
||
102行目: | 106行目: | ||
あるいは、[[#鍵サーバーを使用する|鍵サーバー]]で公開鍵を見つけます。 |
あるいは、[[#鍵サーバーを使用する|鍵サーバー]]で公開鍵を見つけます。 |
||
+ | |||
+ | 特定の Arch Linux パッケージをインストールするためにキー ID をインポートしたい場合は、[[pacman-key#キーリングの管理|キーリングの管理]] と [[Makepkg#署名チェック]] を参照してください。 |
||
=== 鍵サーバーを使用する === |
=== 鍵サーバーを使用する === |
||
+ | |||
+ | ==== 鍵の送信 ==== |
||
自分の公開鍵を公共の PGP 鍵サーバーに登録することで、他の人があなたに直接連絡することなしにあなたの鍵を入手できるようになります: |
自分の公開鍵を公共の PGP 鍵サーバーに登録することで、他の人があなたに直接連絡することなしにあなたの鍵を入手できるようになります: |
||
109行目: | 117行目: | ||
$ gpg --send-keys ''user-id'' |
$ gpg --send-keys ''user-id'' |
||
− | {{Warning|鍵を鍵サーバーに登録してから、サーバーから鍵を削除することはできません [https://pgp.mit.edu/faq.html]。}} |
+ | {{Warning|鍵を鍵サーバーに登録してから、サーバーから鍵を削除することはできません [https://pgp.mit.edu/faq.html]。 その理由は、[https://pgp.mit.edu/faq.html MIT PGP Public Key Server FAQ]で説明されています。}} |
+ | {{Note|関連するメールアドレスが公開されると、スパムメールの標的となる可能性があり、この場合、スパム対策用のフィルタリングが必要となる場合があります。}} |
||
+ | |||
+ | ==== 鍵の検索と受信 ==== |
||
鍵サーバーの鍵の情報を確認したい場合、次のコマンドを実行: |
鍵サーバーの鍵の情報を確認したい場合、次のコマンドを実行: |
||
123行目: | 134行目: | ||
* ID が短いと衝突する可能性があります。インポートされた鍵には全て短い ID が割り当てられます。鍵を受け取るときに完全な指紋か長い鍵 ID を使うことで衝突を回避できます [https://lkml.org/lkml/2016/8/15/445]。 |
* ID が短いと衝突する可能性があります。インポートされた鍵には全て短い ID が割り当てられます。鍵を受け取るときに完全な指紋か長い鍵 ID を使うことで衝突を回避できます [https://lkml.org/lkml/2016/8/15/445]。 |
||
}} |
}} |
||
+ | |||
+ | {{Tip|{{ic|auto-key-retrieve}} を {{ic|gpg.conf}} に追加すると、必要に応じて鍵サーバから鍵を自動的に取得しますが、これは '''プライバシー侵害''' と見なされる可能性があります。{{man|1|gpg}} の "web bug" を参照。}} |
||
+ | |||
+ | ==== 鍵サーバー ==== |
||
+ | |||
+ | 最も一般的な鍵サーバーは次の通りです: |
||
+ | |||
+ | * [https://keyserver.ubuntu.com Ubuntu Keyserver]: 分散型、検証なし、キーは削除不可。 |
||
+ | * [https://keys.mailvelope.com Mailvelope Keyserver]: 中央型、E メール ID の検証、キーは削除可能。 |
||
+ | * [https://keys.openpgp.org keys.openpgp.org]: 中央型、E メール ID の検証、キーは削除可能。サードパーティの署名無し (つまり、Web of Trust のサポートは無し)。 |
||
+ | |||
+ | [[Wikipedia:Key server (cryptographic)#Keyserver examples]] にその他の鍵サーバもあります。 |
||
+ | |||
+ | 代替の鍵サーバは、[[#設定ファイル]]のうちどれかで {{ic|keyserver}} オプションを使用することによって指定することができます。例えば: |
||
+ | |||
+ | {{hc|~/.gnupg/dirmngr.conf| |
||
+ | keyserver hkp://keyserver.ubuntu.com |
||
+ | }} |
||
+ | |||
+ | いつも使用しているサーバが思うように動かない時に、一時的に別のサーバを使用すると便利です。例えば、以下のようにして別のサーバを使用できます: |
||
+ | |||
+ | $ gpg --keyserver ''hkps://keys.openpgp.org/'' --search-keys ''user-id'' |
||
{{Tip| |
{{Tip| |
||
+ | * デフォルトの hkps 鍵サーバプールを使用していて、{{ic|gpg: keyserver receive failed: General error}} というメッセージで失敗する場合、{{ic|dirmngr.conf}} 内で {{ic|hkp-cacert /usr/share/gnupg/sks-keyservers.netCA.pem}} を使用して HKPS プールの検証証明書を設定し、古い dirmngr プロセスを kill してください。 |
||
− | * {{ic|keyserver-options auto-key-retrieve}} を {{ic|gpg.conf}} に追加すると必要に応じて鍵サーバーから鍵が取得されます。 |
||
+ | * {{ic|gpg: keyserver receive failed: Connection refused}} というメッセージで失敗する場合、別の DNS サーバを使ってみてください。 |
||
− | * 代わりの鍵サーバーは {{ic|dirmngr.conf}} の {{ic|--keyserver}} で {{ic|pool.sks-keyservers.net}} と指定できます。[[wikipedia:Key server (cryptographic)#Keyserver examples]] を参照。 |
||
+ | * [[Tor#Torsocks]] で [[Tor]] 経由で鍵サーバに接続することもできます。また、{{ic|--use-tor}} コマンドラインオプションもあります。詳細は [https://gnupg.org/blog/20151224-gnupg-in-november-and-december.html] を参照してください。 |
||
− | * hkp/hkps で使用するポートがブロックされている場合、{{ic|pool.sks-keyservers.net:80}} のようにポート80番を指定してください。 |
||
+ | * {{ic|http_proxy}} [[環境変数]]を設定し、{{ic|dirmngr.conf}} 内で {{ic|honor-http-proxy}} を設定すれば、プロキシを使って鍵サーバに接続することもできます。また、設定ファイル内で {{ic|http-proxy ''host[:port]''}} を使えば、先の環境変数をオーバーライドすることができます。変更を適用するには、{{ic|dirmngr.service}} [[ユーザーユニット]]を[[再起動]]してください。 |
||
− | * {{ic|--use-tor}} を使うと [[Tor]] で鍵サーバーに接続できます。[https://gnupg.org/blog/20151224-gnupg-in-november-and-december.html GnuPG のブログ記事] を参照。 |
||
+ | * {{ic|gpg: keyserver receive failed: Server indicated a failure}} というメッセージで鍵サーバに接続できない場合、別のポートを使用するように gpg を設定する必要があるのかもしれません。例えば、Ubuntu の鍵サーバで80番ポートを使用するには、{{ic|keyserver hkp://keyserver.ubuntu.com:80}} と設定してください。 |
||
− | * {{ic|http_proxy}} 環境変数を設定して {{ic|dirmngr.conf}} で {{ic|honor-http-proxy}} を設定することでプロキシを使って鍵サーバーに接続できます。また、{{ic|dirmngr.conf}} で {{ic|http-proxy ''host[:port]''}} を設定すると {{ic|http_proxy}} 環境変数が上書きされます。 |
||
+ | }} |
||
− | * 特定の Arch Linux パッケージをインストールするのに鍵 ID をインポートしたい場合、[[pacman-key#キーリングの管理]]や [[Makepkg#署名チェック]]を参照してください。}} |
||
+ | |||
+ | === Web Key Directory === |
||
+ | |||
+ | Web Key Service (WKS) プロトコルは、鍵配布のための新しい [https://datatracker.ietf.org/doc/draft-koch-openpgp-webkey-service/ 標準]で、電子メールドメインが [https://wiki.gnupg.org/WKD Web Key Directory (WKD)] という独自の鍵サーバーを提供するものです。電子メールアドレス (例 : {{ic|user@example.com}}) に暗号化するとき、GnuPG (>=2.1.16) は、公開鍵をローカル鍵束にまだ持っていなければ、 HTTPS でそのドメイン ({{ic|example.com}}) に照会します。オプション {{ic|auto-key-locate}} は、このメールアドレスのローカル鍵束に鍵がない場合、WKD プロトコルを使って鍵を探します。 |
||
+ | |||
+ | # gpg --recipient ''user@example.org'' --auto-key-locate --encrypt ''doc'' |
||
+ | |||
+ | WKD をサポートしているメールプロバイダーの一覧は [https://wiki.gnupg.org/WKD#Implementations GnuPG Wiki] を参照してください。メールアドレスのドメインを自分で管理している場合は、[https://wiki.gnupg.org/WKDHosting このガイド]に従って、自分のドメインで WKD を有効にすることができます。あなたの鍵が WKD で見つかるかどうかを確認するには、[https://metacode.biz/openpgp/web-key-directory このウェブインターフェイス]が使用できます。 |
||
=== 暗号化と復号化 === |
=== 暗号化と復号化 === |
||
174行目: | 215行目: | ||
$ gpg --output ''doc'' --decrypt ''doc''.gpg |
$ gpg --output ''doc'' --decrypt ''doc''.gpg |
||
+ | |||
+ | ==== ディレクトリ ==== |
||
+ | |||
+ | ディレクトリの暗号化・復号化は {{man|1|gpgtar}} で行うことができます。 |
||
+ | |||
+ | 暗号化: |
||
+ | $ gpgtar -c -o ''dir''.gpg ''dir'' |
||
+ | |||
+ | 復号化: |
||
+ | $ gpgtar -d ''dir''.gpg |
||
== 鍵の管理 == |
== 鍵の管理 == |
||
189行目: | 240行目: | ||
秘密鍵のバックアップをインポートするには: |
秘密鍵のバックアップをインポートするには: |
||
$ gpg --import ''privkey.asc'' |
$ gpg --import ''privkey.asc'' |
||
+ | |||
+ | === 失効証明書のバックアップ === |
||
+ | |||
+ | 失効証明書は、新しく生成されたキーに対して自動的に生成されます。これらはデフォルトで {{ic|~/.gnupg/openpgp-revocs.d/}} にあります。証明書のファイル名は、取り消すキーのフィンガープリントです。 |
||
+ | 失効証明書は、ユーザーが後で次を使用して手動で生成することもできます。 |
||
+ | |||
+ | $ gpg --gen-revoke --armor --output ''revcert.asc'' ''user-id'' |
||
+ | |||
+ | この証明書は、紛失または侵害された場合に [[#鍵の取り消し]] に使用できます。バックアップは、秘密鍵にアクセスできなくなったため、上記のコマンドで新しい失効証明書を生成できない場合に役立ちます。必要に応じて印刷して手で入力できるほど短いです。 |
||
+ | |||
+ | {{Warning|失効証明書にアクセスできる人は誰でも、キーを公に失効させることができます。このアクションは元に戻すことはできません。秘密鍵を保護するのと同じように、失効証明書を保護します。}} |
||
=== 鍵の編集 === |
=== 鍵の編集 === |
||
249行目: | 311行目: | ||
これで、他のデバイスで {{ic|/tmp/subkey.altpass.gpg}} を使うことができます。 |
これで、他のデバイスで {{ic|/tmp/subkey.altpass.gpg}} を使うことができます。 |
||
− | === |
+ | === 有効期限の延長 === |
{{Warning|何か特段の事情がないかぎり、有効期限が切れたり無効になった副鍵を削除しないでください。削除してしまうとその副鍵で暗号化したファイルを復号化できなくなってしまいます。満了した、または無効のキーを削除するのは他のユーザーの鍵束を整理するときだけにしてください。}} |
{{Warning|何か特段の事情がないかぎり、有効期限が切れたり無効になった副鍵を削除しないでください。削除してしまうとその副鍵で暗号化したファイルを復号化できなくなってしまいます。満了した、または無効のキーを削除するのは他のユーザーの鍵束を整理するときだけにしてください。}} |
||
268行目: | 330行目: | ||
> save |
> save |
||
− | * |
+ | * 鍵サーバーにアップデート: |
$ gpg --keyserver pgp.mit.edu --send-keys ''<user-id>'' |
$ gpg --keyserver pgp.mit.edu --send-keys ''<user-id>'' |
||
+ | また、この鍵を複数のコンピュータで使用する場合は、公開鍵(新しい署名付き有効期限付き)をエクスポートして、それらのマシンでインポートすることもできます。 |
||
− | {{Tip|満了した副鍵を失効させる必要はありません、また、良い行いとは言えません。しょっちゅう鍵を無効化させているようでしたら、他人はあなたを信用しなくなるかもしれません。}} |
||
+ | |||
+ | $ gpg --export --output pubkey.gpg ''user-id'' |
||
+ | $ gpg --import pubkey.gpg |
||
+ | |||
+ | 秘密鍵の再エクスポートやバックアップの更新は必要ありません。マスター秘密鍵自体に有効期限がなく、公開鍵やサブ鍵に残された有効期限の署名があればよいのです。 |
||
+ | |||
+ | === Rotating subkeys === |
||
+ | |||
+ | {{Warning|'''Never''' delete your expired or revoked subkeys unless you have a good reason. Doing so will cause you to lose the ability to decrypt files encrypted with the old subkey. Please '''only''' delete expired or revoked keys from other users to clean your keyring.}} |
||
+ | |||
+ | Alternatively, if you prefer to stop using subkeys entirely once they have expired, you can create new ones. Do this a few weeks in advance to allow others to update their keyring. |
||
+ | |||
+ | {{Tip|You do not need to create a new key simply because it is expired. You can extend the expiration date, see the section [[#Extending expiration date]].}} |
||
+ | |||
+ | Create new subkey (repeat for both signing and encrypting key) |
||
+ | |||
+ | $ gpg --edit-key ''user-id'' |
||
+ | > addkey |
||
+ | |||
+ | And answer the following questions it asks (see [[#Create a key pair]] for suggested settings). |
||
+ | |||
+ | Save changes |
||
+ | |||
+ | > save |
||
+ | |||
+ | Update it to a keyserver. |
||
+ | |||
+ | $ gpg --keyserver pgp.mit.edu --send-keys ''user-id'' |
||
+ | |||
+ | You will also need to export a fresh copy of your secret keys for backup purposes. See the section [[#Backup your private key]] for details on how to do this. |
||
+ | |||
+ | {{Tip|Revoking expired subkeys is unnecessary and arguably bad form. If you are constantly revoking keys, it may cause others to lack confidence in you.}} |
||
+ | |||
+ | === 鍵の取り消し === |
||
+ | |||
+ | 鍵が侵害された、置き換えられた、使用されなくなった、またはパスフレーズを忘れた場合は、キーの取り消しを実行する必要があります。これは、鍵を鍵の失効証明書とマージすることによって行われます。 |
||
+ | |||
+ | 鍵ペアにアクセスできなくなった場合は、まず[[#公開鍵のインポート]]して独自の鍵をインポートします。 |
||
+ | 次に、キーを失効させるために、[[#失効証明書のバックアップ]] で保存したファイルをインポートします。 |
||
+ | |||
+ | $ gpg --import ''revcert.asc'' |
||
+ | |||
+ | ここで、取り消しを公開する必要があります。 [[#鍵サーバーを使用する]]で過去に PGP サーバーを使用したことがある場合は、取り消された鍵を公開 PGP サーバーに送信します。それ以外の場合は、取り消された鍵をファイルにエクスポートし、通信パートナーに配布します。 |
||
== 署名 == |
== 署名 == |
||
278行目: | 383行目: | ||
署名は文章を証明します。文章が改変された場合、署名の検証に失敗します。公開鍵を使用して文章を暗号化する暗号化とは違って、署名はユーザーの秘密鍵を使って作成されます。署名された文章を受け取った人は送り主の公開鍵を使って署名を検証できます。 |
署名は文章を証明します。文章が改変された場合、署名の検証に失敗します。公開鍵を使用して文章を暗号化する暗号化とは違って、署名はユーザーの秘密鍵を使って作成されます。署名された文章を受け取った人は送り主の公開鍵を使って署名を検証できます。 |
||
− | === |
+ | === 署名の作成 === |
+ | |||
+ | ==== ファイルに署名する ==== |
||
ファイルに署名するには {{ic|--sign}} または {{ic|-s}} フラグを使います: |
ファイルに署名するには {{ic|--sign}} または {{ic|-s}} フラグを使います: |
||
286行目: | 393行目: | ||
上記のコマンドは暗号化も行ってファイルをバイナリ形式で保存します。 |
上記のコマンドは暗号化も行ってファイルをバイナリ形式で保存します。 |
||
− | === ファイルやメッセージにクリア署名 === |
+ | ==== ファイルやメッセージにクリア署名 ==== |
バイナリ形式に圧縮しないでファイルに署名するには: |
バイナリ形式に圧縮しないでファイルに署名するには: |
||
294行目: | 401行目: | ||
上記のコマンドは文章を ASCII-armored 署名でラッピングしますが、文章に変更は加えられません。 |
上記のコマンドは文章を ASCII-armored 署名でラッピングしますが、文章に変更は加えられません。 |
||
− | === 分離署名を作成する === |
+ | ==== 分離署名を作成する ==== |
文章やファイルとは別に署名ファイルを作成したい場合、{{ic|--detach-sig}} フラグを使ってください: |
文章やファイルとは別に署名ファイルを作成したい場合、{{ic|--detach-sig}} フラグを使ってください: |
||
302行目: | 409行目: | ||
上記の方法はソフトウェアプロジェクトを配布するときによく用いられます。署名書を検証することで第三者によってファイルが改竄されていないことが確認できます。 |
上記の方法はソフトウェアプロジェクトを配布するときによく用いられます。署名書を検証することで第三者によってファイルが改竄されていないことが確認できます。 |
||
− | === 署名の検証 === |
+ | ==== 署名の検証 ==== |
署名を検証するには {{ic|--verify}} フラグを使います: |
署名を検証するには {{ic|--verify}} フラグを使います: |
||
317行目: | 424行目: | ||
{{ic|archlinux-''version''.iso}} が同じディレクトリに存在していなければなりません。 |
{{ic|archlinux-''version''.iso}} が同じディレクトリに存在していなければなりません。 |
||
+ | |||
+ | === 署名の確認 === |
||
+ | |||
+ | 署名を確認するには、{{ic|--verify}} フラグを使用します。 |
||
+ | |||
+ | $ gpg --verify ''doc''.sig |
||
+ | |||
+ | ここで {{ic|''doc''.sig}} は、検証したい署名を含む署名付きファイルです。 |
||
+ | |||
+ | 分離された署名を検証する場合、署名されたデータファイルと署名ファイルの両方が検証時に存在する必要があります。例えば、Arch Linux の最新の iso を検証する場合、次のようになります。 |
||
+ | |||
+ | $ gpg --verify archlinux-''version''.iso.sig |
||
+ | |||
+ | ここで {{ic|archlinux-''version''.iso}} は同じディレクトリにある必要があります。 |
||
+ | |||
+ | また、第2引数で署名付きデータファイルを指定することも可能です。 |
||
+ | |||
+ | $ gpg --verify archlinux-''version''.iso.sig ''/path/to/''archlinux-''version''.iso |
||
+ | |||
+ | 署名に加えて暗号化されている場合は、[[#暗号化と復号化|復号化]]を行うだけで署名も検証されます。 |
||
== gpg-agent == |
== gpg-agent == |
||
324行目: | 451行目: | ||
* ''gpg'' はメインの {{ic|gpg-agent.socket}} を使って ''gpg-agent'' デーモンに接続します。 |
* ''gpg'' はメインの {{ic|gpg-agent.socket}} を使って ''gpg-agent'' デーモンに接続します。 |
||
* {{ic|gpg-agent-extra.socket}} はリモート環境から Unix ドメインソケットの転送を設定します。秘密鍵をリモート環境に移さなくてもリモート環境で ''gpg'' が使えるようになります。詳しくは {{man|1|gpg-agent}} を参照。 |
* {{ic|gpg-agent-extra.socket}} はリモート環境から Unix ドメインソケットの転送を設定します。秘密鍵をリモート環境に移さなくてもリモート環境で ''gpg'' が使えるようになります。詳しくは {{man|1|gpg-agent}} を参照。 |
||
+ | * The {{ic|gpg-agent-browser.socket}} allows web browsers to access the ''gpg-agent'' daemon. |
||
* [[SSH]] は {{ic|gpg-agent-ssh.socket}} を使って ''ssh-add'' プログラムによって追加された [[SSH 鍵]]をキャッシュします。必要な設定は [[#SSH エージェント]]を見てください。 |
* [[SSH]] は {{ic|gpg-agent-ssh.socket}} を使って ''ssh-add'' プログラムによって追加された [[SSH 鍵]]をキャッシュします。必要な設定は [[#SSH エージェント]]を見てください。 |
||
* {{ic|dirmngr.socket}} は鍵サーバーへの接続を処理する GnuPG デーモンを起動します。 |
* {{ic|dirmngr.socket}} は鍵サーバーへの接続を処理する GnuPG デーモンを起動します。 |
||
350行目: | 478行目: | ||
シェルに {{ic|OK}} と出力されます。 |
シェルに {{ic|OK}} と出力されます。 |
||
+ | |||
+ | しかし、エージェント設定に {{ic|keep-screen}} が追加されている場合など、再起動だけでは十分でないこともあります。 |
||
+ | この場合、まず進行中の gpg-agent プロセスを kill してから、上記で説明したように再起動する必要があります。 |
||
=== pinentry === |
=== pinentry === |
||
+ | {{ic|gpg-agent}} は {{ic|pinentry-program}} stanza を使用して、パスフレーズの入力を促す際に、特定の {{Pkg|pinentry}} ユーザーインターフェイスを使用するように設定できます。例えば、以下の通りです。 |
||
− | 最後に、ユーザーにパスワードを尋ねる方法をエージェントに設定する必要があります。gpg-agent の設定ファイルで設定できます。 |
||
− | デフォルトでは gtk のダイアログが使われます。使用できるオプションは {{ic|info pinentry}} を見て下さい。ダイアログの実装を変更するには {{ic|pinentry-program}} 設定オプションを設定します: |
||
{{hc|~/.gnupg/gpg-agent.conf| |
{{hc|~/.gnupg/gpg-agent.conf| |
||
+ | pinentry-program /usr/bin/pinentry-curses |
||
− | |||
− | # PIN entry program |
||
− | # pinentry-program /usr/bin/pinentry-curses |
||
− | # pinentry-program /usr/bin/pinentry-qt |
||
− | # pinentry-program /usr/bin/pinentry-kwallet |
||
− | |||
− | pinentry-program /usr/bin/pinentry-gtk-2 |
||
}} |
}} |
||
+ | |||
+ | 他のも様々な pinentry プログラムがあります。{{ic|pacman -Ql pinentry {{!}} grep /usr/bin/}} を参照してください。 |
||
{{Tip|{{ic|/usr/bin/pinentry-kwallet}} を使うには {{AUR|kwalletcli}} パッケージをインストールする必要があります。}} |
{{Tip|{{ic|/usr/bin/pinentry-kwallet}} を使うには {{AUR|kwalletcli}} パッケージをインストールする必要があります。}} |
||
− | 変更を行った後は、 |
+ | 変更を行った後は、[[#エージェントのリロード|エージェントのリロード]]を忘れないでください。 |
+ | |||
+ | === パスワードのキャッシュ === |
||
+ | |||
+ | GnuPG のパスワードをセッションの間だけ記憶させたい場合、{{ic|max-cache-ttl}} と {{ic|default-cache-ttl}} を高い値に設定してください: |
||
+ | |||
+ | {{hc| |
||
+ | gpg-agent.conf| |
||
+ | max-cache-ttl 60480000 |
||
+ | default-cache-ttl 60480000 |
||
+ | }} |
||
+ | |||
+ | 詳しくは [[#gpg-agent]] を参照。 |
||
=== 無人のパスフレーズ === |
=== 無人のパスフレーズ === |
||
409行目: | 547行目: | ||
{{note| |
{{note| |
||
* {{ic|SSH_AUTH_SOCK}} を手動で設定する場合、{{ic|GNUPGHOME}} をカスタマイズしているときはソケットの場所が異なる可能性があるので注意してください。以下の bash の例を使用するか、{{ic|SSH_AUTH_SOCK}} を {{ic|gpgconf --list-dirs agent-ssh-socket}} の値に変更してください。 |
* {{ic|SSH_AUTH_SOCK}} を手動で設定する場合、{{ic|GNUPGHOME}} をカスタマイズしているときはソケットの場所が異なる可能性があるので注意してください。以下の bash の例を使用するか、{{ic|SSH_AUTH_SOCK}} を {{ic|gpgconf --list-dirs agent-ssh-socket}} の値に変更してください。 |
||
+ | * GNOME Keyring がインストールされている場合、 その ssh コンポーネントを[[GNOME/Keyring#無効化する|無効化]]する必要があります。そうしないと、{{ic|SSH_AUTH_SOCK}} を上書きしてしまいます。}} |
||
− | * If GNOME Keyring is installed, it is necessary to [[GNOME/Keyring#Disable keyring daemon components|deactivate]] its ssh component. Otherwise, it will overwrite {{ic|SSH_AUTH_SOCK}}. |
||
− | }} |
||
または、Bash を使う場合: |
または、Bash を使う場合: |
||
435行目: | 572行目: | ||
</nowiki>}} |
</nowiki>}} |
||
+ | 複数の端末を同時に使用し、''ssh'' コマンドを実行した同じ端末から ''pinentry-curses'' で ''gpg-agent'' がパスフレーズを要求するようにしたい場合、SSH 設定ファイルに以下を追加してください。これにより、''ssh'' コマンドを実行するたびに TTY がリフレッシュされるようになります [https://unix.stackexchange.com/a/499133]。 |
||
− | If you use multiple terminals simultaneously and want ''gpg-agent'' to ask for passphrase via ''pinentry-curses'' from the same terminal where the ''ssh'' command was run, add the following to the SSH configuration file. This will make the TTY to be refreshed every time an ''ssh'' command is run [https://unix.stackexchange.com/a/499133]: |
||
{{hc|~/.ssh/config|2= |
{{hc|~/.ssh/config|2= |
||
441行目: | 578行目: | ||
}} |
}} |
||
+ | なお、環境変数 GPG_TTY が設定されていないと動作しません。 |
||
− | Note that GPG_TTY environment variable has to be set for this to work. |
||
==== SSH 鍵の追加 ==== |
==== SSH 鍵の追加 ==== |
||
451行目: | 588行目: | ||
max-cache-ttl-ssh 10800}} |
max-cache-ttl-ssh 10800}} |
||
− | ==== |
+ | ==== SSH 認証に PGP 鍵を使用する ==== |
− | + | PGP 鍵を SSH 鍵として使うこともできます。鍵のメンテナンスを楽にして SSH 鍵をキーカードに保存できます。認証機能を有効にして鍵を作成する必要があります ([[#カスタム機能]]を参照)。SSH 認証に PGP 鍵を使用することで得られる様々な利点があります。 |
|
+ | * SSH キーを維持する必要がなくなるため、キーのメンテナンスが削減されます。 |
||
− | $ ssh-add -l |
||
+ | * 認証キーをスマートカードに保存する能力。GnuPG はカードが利用可能なときにキーを自動的に検出し、エージェントに追加します({{ic|ssh-add -l}} または {{ic|ssh-add -L}} で確認)。キーのコメントは次のようなものであるべきです:{{ic|openpgp:''key-id''}} または {{ic|cardno:''card-id''}}。 |
||
+ | GPG/SSH キーの公開キー部分を取得するには、{{ic|gpg --export-ssh-key ''gpg-key''}} を実行します。キーが認証可能であっても、このコマンドが "Unusable public key" で失敗する場合は、{{ic|!}} サフィックスを追加します ([https://dev.gnupg.org/T2957])。 |
||
− | 鍵のコメントが次のようになっていれば追加されています: {{ic|openpgp:''key-id''}} または {{ic|cardno:''card-id}}。 |
||
+ | GPG キーをキーカードに持っていない場合、SSH キーとして認識されるように {{ic|$GNUPGHOME/sshcontrol}} にキーを追加する必要があります。キーがキーカードにある場合、その keygrip は {{ic|sshcontrol}} に暗黙的に追加されます。そうでない場合、次の方法でキーの keygrip を取得します: |
||
− | {{note|GnuPG は GnuPG 鍵を (通常の SSH 鍵が保存される) {{ic|$GNUPGHOME/sshcontrol}} に追加しない場合があります。}} |
||
+ | {{hc|$ gpg --list-keys --with-keygrip|2= |
||
− | == スマートカード == |
||
+ | sub rsa4096 2018-07-25 [A] |
||
+ | Keygrip = ''1531C8084D16DC4C36911F1585AF0ACE7AAFD7E7'' |
||
+ | }} |
||
+ | その後、{{ic|sshcontrol}} をこのように編集します。keygrip を追加するのは一度だけの操作です。追加のキーを追加する場合を除いて、ファイルを再度編集する必要はありません。 |
||
− | {{Note|{{Pkg|pcsclite}} と {{Pkg|libusb-compat}} をインストールして、{{ic|pcscd.service}} サービスを [[systemd#ユニットを使う|systemd]] で実行する必要があります。}} |
||
+ | {{hc|$GNUPGHOME/sshcontrol| |
||
− | GnuPG はスマートカードリーダーのインターフェイスとして ''scdaemon'' を使います。詳しくは [[man ページ]]を参照してください。 |
||
+ | ''1531C8084D16DC4C36911F1585AF0ACE7AAFD7E7'' |
||
+ | }} |
||
+ | |||
+ | == スマートカード == |
||
+ | |||
+ | GnuPG は、スマートカードリーダとのインターフェイスとして ''scdaemon'' を使用します。詳細は {{man|1|scdaemon}} [[man ページ]]を参照してください。 |
||
=== GnuPG のみ設定 === |
=== GnuPG のみ設定 === |
||
+ | |||
+ | {{Note|scdaemon が USB スマートカードリーダに直接アクセスできるようにするには、任意の依存パッケージである {{Pkg|libusb-compat}} をインストールする必要があります。}} |
||
GnuPG ベース以外のカードを使う予定がない場合は、{{ic|~/.gnupg/scdaemon.conf}} の {{Ic|reader-port}} パラメータを確認してください。'0' が最初に利用できるシリアルポートリーダーを、'32768' (デフォルト) が最初の USB リーダーを示しています。 |
GnuPG ベース以外のカードを使う予定がない場合は、{{ic|~/.gnupg/scdaemon.conf}} の {{Ic|reader-port}} パラメータを確認してください。'0' が最初に利用できるシリアルポートリーダーを、'32768' (デフォルト) が最初の USB リーダーを示しています。 |
||
− | === GnuPG と |
+ | === GnuPG と pcscd (PCSC Lite) === |
+ | {{man|8|pcscd}} は、スマートカードへのアクセスを管理するデーモンです (SCard API)。(GnuPG の内臓の CCID サポートを使うなどして) GnuPG の scdaemon でスマートカードと直接接続できない場合、このデーモンは PCSC Lite ドライバを使用するスマートカードを見つけようとします。 |
||
− | opensc ドライバーであらゆるスマートカードを使う場合は (例: いろいろな国の ID カード)、GnuPG の設定に注意する必要があります。何も設定をしていないと {{Ic|gpg --card-status}} を使った時に以下のようなメッセージが表示されることがあります: |
||
+ | |||
+ | pscsd を使うには、{{Pkg|pcsclite}} と {{Pkg|ccid}} を[[インストール]]してください。そして、{{ic|pcscd.service}} を[[開始]]し、(このサービスを永続的に使用する場合は) [[有効化]]してください。あるいは、{{ic|pcscd.socket}} を開始/有効化することで、必要なときにだけデーモンをアクティブ化させることもできます。 |
||
+ | |||
+ | ==== 常に pcscd を使う ==== |
||
+ | |||
+ | opensc ドライバを使用するスマートカード (一部の国々の ID カードがこれに該当します) を使う場合は、GnuPG の設定に注意する必要があります。特に設定しないと、{{Ic|gpg --card-status}} を実行した時に以下のようなメッセージが表示されるかもしれません: |
||
gpg: selecting openpgp failed: ec=6.108 |
gpg: selecting openpgp failed: ec=6.108 |
||
− | デフォルトでは、scdaemon はデバイスに直接接続しようとします。リーダ |
+ | デフォルトでは、scdaemon はデバイスに直接接続しようとします。カードリーダが他のプロセスによって使用されている場合、この接続は失敗します。例えば、pcscd デーモンが OpenSC によって使用されている場合などです。この問題を解決するには、scdaemon と opensc が互いにうまく機能するようにするために、opensc のものと同じドライバを使用する必要があります。scdaemon が pcscd を使用するようにするには、{{ic|~/.gnupg/scdaemon.conf}} から {{Ic|reader-port}} を削除し、{{ic|libpcsclite.so}} ライブラリへのパスを指定し、pcscd を確実に使用させるために ccid を無効化する必要があります: |
{{hc|~/.gnupg/scdaemon.conf|<nowiki> |
{{hc|~/.gnupg/scdaemon.conf|<nowiki> |
||
485行目: | 640行目: | ||
</nowiki>}} |
</nowiki>}} |
||
− | OpenSC を使 |
+ | OpenSC を使用しない場合は、{{man|1|scdaemon}} を確認してください。 |
+ | |||
+ | ==== pcscd との共有アクセス ==== |
||
+ | |||
+ | GnuPG {{ic|scdaemon}} is the only popular {{ic|pcscd}} client that uses {{ic|PCSC_SHARE_EXCLUSIVE}} flag when connecting to {{ic|pcscd}}. Other clients like OpenSC PKCS#11 that are used by browsers and programs listed in [[Electronic identification]] are using {{ic|PCSC_SHARE_SHARED}} that allows simultaneous access to single smartcard. {{ic|pcscd}} will not give exclusive access to smartcard while there are other clients connected. This means that to use GnuPG smartcard features you must before have to close all your open browser windows or do some other inconvenient operations. Starting from version 2.2.28 LTS and 2.3.0 you can enable shared access by modifying your {{ic|scdaemon.conf}} file and adding {{ic|pcsc-shared}} line end of it. |
||
+ | |||
+ | ===== マルチアプレットスマートカード ===== |
||
+ | |||
+ | When using [[YubiKey]]s or other multi applet USB dongles with OpenSC PKCS#11 may run into problems where OpenSC switches your Yubikey from OpenPGP to PIV applet, breaking the {{ic|scdaemon}}. |
||
+ | |||
+ | You can hack around the problem by forcing OpenSC to also use the OpenPGP applet. Open {{ic|/etc/opensc.conf}} file, search for Yubikey and change the {{ic|1=driver = "PIV-II";}} line to {{ic|1=driver = "openpgp";}}. If there is no such entry, use {{ic|pcsc_scan}}. Search for the Answer to Reset {{ic|ATR: 12 34 56 78 90 AB CD ...}}. Then create a new entry. |
||
+ | |||
+ | {{hc|/etc/opensc.conf|2= |
||
+ | ... |
||
+ | card_atr 12:23:34:45:67:89:ab:cd:... { |
||
+ | name = "YubiKey Neo"; |
||
+ | driver = "openpgp" |
||
+ | } |
||
+ | ... |
||
+ | }} |
||
+ | |||
+ | After that you can test with {{ic|pkcs11-tool -O --login}} that the OpenPGP applet is selected by default. Other PKCS#11 clients like browsers may need to be restarted for that change to be applied. |
||
+ | |||
+ | ===== SSH 経由でリモートクライアント上のスマートカードを使用する ===== |
||
+ | |||
+ | If you log into a machine via SSH and try to use an attached device via pcscd, you will notice errors such as: |
||
+ | |||
+ | gpg: selecting card failed: No such device |
||
+ | gpg: OpenPGP card not available: No such device |
||
+ | |||
+ | This is due to [[Polkit]] restricting access to local clients. To fix this, you can add a rule to allow certain users in all cases. The below rule allows all users in the {{ic|wheel}} group to access devices via {{ic|pcscd}}: |
||
+ | |||
+ | {{hc|/etc/polkit-1/rules.d/99-pcscd.rules|2= |
||
+ | polkit.addRule(function(action, subject) { |
||
+ | if (action.id == "org.debian.pcsc-lite.access_card" && |
||
+ | subject.isInGroup("wheel")) { |
||
+ | return polkit.Result.YES; |
||
+ | } |
||
+ | }); |
||
+ | polkit.addRule(function(action, subject) { |
||
+ | if (action.id == "org.debian.pcsc-lite.access_pcsc" && |
||
+ | subject.isInGroup("wheel")) { |
||
+ | return polkit.Result.YES; |
||
+ | } |
||
+ | }); |
||
+ | }} |
||
+ | |||
+ | After creating the file, make sure to [[restart]] {{ic|polkit.service}}. |
||
== ヒントとテクニック == |
== ヒントとテクニック == |
||
546行目: | 748行目: | ||
=== キーサインパーティで caff を使う === |
=== キーサインパーティで caff を使う === |
||
− | + | 鍵サーバーやキーリングにある鍵の正当性をユーザーが確認 (つまり鍵の持ち主が本人であることを確認) できるように、PGP/GPG はいわゆる信頼の輪 ("Web of Trust") を利用しています。信頼の輪を維持するために様々なハッカーイベントが開かれており、キーサインパーティはそのひとつです。[[Wikipedia:Zimmermann–Sassaman key-signing protocol|Zimmermann-Sassaman]] 鍵署名プロトコルはキーサインパーティを効果的に行うための方式です。[http://www.cryptnet.net/fdp/crypto/keysigning_party/en/keysigning_party.html こちら] にハウツー記事があります。 |
|
キーサインパーティの後、鍵に署名したり所有者に署名を送るのを簡略化するために、''caff'' というツールを使うことができます。AUR のパッケージ {{AUR|caff-svn}} でインストールすることができます。 |
キーサインパーティの後、鍵に署名したり所有者に署名を送るのを簡略化するために、''caff'' というツールを使うことができます。AUR のパッケージ {{AUR|caff-svn}} でインストールすることができます。 |
||
572行目: | 774行目: | ||
副鍵にカスタム機能を指定したい場合、{{ic|gpg --edit-key}} に {{ic|--expert}} フラグを追加してください。詳しくは[[#鍵の編集]]を参照。 |
副鍵にカスタム機能を指定したい場合、{{ic|gpg --edit-key}} に {{ic|--expert}} フラグを追加してください。詳しくは[[#鍵の編集]]を参照。 |
||
− | |||
− | === パスワードのキャッシュ === |
||
− | |||
− | GnuPG のパスワードをセッションの間だけ記憶させたい場合、{{ic|max-cache-ttl}} と {{ic|default-cache-ttl}} を高い値に設定してください: |
||
− | |||
− | {{hc| |
||
− | gpg-agent.conf| |
||
− | max-cache-ttl 60480000 |
||
− | default-cache-ttl 60480000 |
||
− | }} |
||
− | |||
− | 詳しくは [[#gpg-agent]] を参照。 |
||
== トラブルシューティング == |
== トラブルシューティング == |
||
− | |||
− | === http プロキシを使う === |
||
− | 2.1.9 から http プロキシのオプションは以下のように設定できます: |
||
− | |||
− | $ gpg --keyserver-option http-proxy=HOST:PORT |
||
− | |||
− | 詳しくは https://bugs.gnupg.org/gnupg/issue1786 を参照。 |
||
=== Not enough random bytes available === |
=== Not enough random bytes available === |
||
614行目: | 797行目: | ||
{{Note|tty の所有者が pinentry を実行しているユーザーと一致している必要があります。{{Ic|tty}} グループに属しているだけでは不十分です。}} |
{{Note|tty の所有者が pinentry を実行しているユーザーと一致している必要があります。{{Ic|tty}} グループに属しているだけでは不十分です。}} |
||
− | {{Tip|{{ic|script}} で gpg を実行した場合、新しい tty が適切な所有権で使われます: |
+ | {{Tip|{{ic|script}} で gpg を実行した場合、新しい tty が適切な所有権で使われます: |
+ | |||
+ | # script -q -c "gpg --gen-key" /dev/null |
||
+ | }} |
||
=== エージェントがファイルの終末についてエラーを表示する === |
=== エージェントがファイルの終末についてエラーを表示する === |
||
657行目: | 843行目: | ||
$ gpg --list-keys |
$ gpg --list-keys |
||
− | === (鍵を受信しようとすると) どの |
+ | === (鍵を受信しようとすると) どの鍵サーバーでも gpg がフリーズする === |
− | 特定の |
+ | 特定の鍵サーバーで鍵を受信しようとして gpg がフリーズしている場合、dirmngr を kill して (問題が起こっていない) 他の鍵サーバーにアクセスできるようにする必要があります。そうしないと全ての鍵サーバーでフリーズしてしまいます。 |
=== スマートカードが検出されない === |
=== スマートカードが検出されない === |
||
665行目: | 851行目: | ||
スマートカードにアクセスするための権限がない場合、カードを正しく設定して接続しても、{{ic|card error}} が表示されることがあります。 |
スマートカードにアクセスするための権限がない場合、カードを正しく設定して接続しても、{{ic|card error}} が表示されることがあります。 |
||
− | スマートカードにアクセスする必要があるユーザーに {{ic|scard}} を追加することで解決できます。追加したら、以下のような [[Udev#udev ルール |
+ | スマートカードにアクセスする必要があるユーザーに {{ic|scard}} を追加することで解決できます。追加したら、以下のような [[Udev#udev ルールについて|udev]] ルールを作って下さい: |
{{hc|/etc/udev/rules.d/71-gnupg-ccid.rules|<nowiki> |
{{hc|/etc/udev/rules.d/71-gnupg-ccid.rules|<nowiki> |
||
ACTION=="add", SUBSYSTEM=="usb", ENV{ID_VENDOR_ID}=="1050", ENV{ID_MODEL_ID}=="0116|0111", MODE="660", GROUP="scard" |
ACTION=="add", SUBSYSTEM=="usb", ENV{ID_VENDOR_ID}=="1050", ENV{ID_MODEL_ID}=="0116|0111", MODE="660", GROUP="scard" |
||
675行目: | 861行目: | ||
{{ic|gnupg}} をアップグレードしたのに古い gpg-agent が動作し続けていると警告が表示されます。ユーザーの {{ic|gpg-agent.socket}} を再起動してください (再起動するときに {{ic|--user}} フラグを使ってください)。 |
{{ic|gnupg}} をアップグレードしたのに古い gpg-agent が動作し続けていると警告が表示されます。ユーザーの {{ic|gpg-agent.socket}} を再起動してください (再起動するときに {{ic|--user}} フラグを使ってください)。 |
||
+ | |||
+ | === IPC 接続の呼び出しに失敗 === |
||
+ | |||
+ | {{ic|killall gpg-agent dirmngr}} と {{ic|$GNUPGHOME/crls.d/}} フォルダの権限が {{ic|700}} になっていて、{{ic|gpg-agent}} と {{ic|dirmngr}} が起動していないことを確認してください. |
||
+ | |||
+ | デフォルトでは、{{Pkg|gnupg}} パッケージは、ソケットのために {{ic|/run/user/$UID/gnupg/}} ディレクトリを使用します。[https://github.com/gpg/gnupg/blob/25ae80b8eb6e9011049d76440ad7d250c1d02f7c/README#L121-L122 GnuPG documentation] には、このディレクトリが望ましいと書かれています (すべてのファイルシステムがソケットに対応しているわけではありません)。あなたの {{ic|agent-socket}} の設定が、適切なファイルシステムを持つパスを指定しているかどうか確認してください。ic|agent-socket}} のパス設定は、 {{ic|gpgconf --list-dirs agent-socket}} を実行することで確認することができます。 |
||
+ | |||
+ | {{ic|gpg-agent}} が正常に起動するか、{{ic|gpg-agent --daemon}} でテストしてください。 |
||
+ | |||
+ | === 汚染された PGP 証明書の軽減 === |
||
+ | |||
+ | 2019 年 6 月、未知の攻撃者が数万(または数十万)の署名を持つ複数の高プロファイル PGP 証明書をスパム送信し(CVE-2019-13050)、これらの署名を SKS 鍵サーバーにアップロードしていました。 |
||
+ | これらの汚染された証明書がキーリングに存在すると、gpg は以下のメッセージを表示してハングします。 |
||
+ | |||
+ | gpg: removing stale lockfile (created by 7055) |
||
+ | |||
+ | この場合、[https://tech.michaelaltfield.net/2019/07/14/mitigating-poisoned-pgp-certificates/ ブログポスト]にあるように、汚染された証明書を削除することで軽減できる可能性があります。 |
||
+ | |||
+ | === IPC 応答が無効であり、デバイスの ioctl が不適切 === |
||
+ | |||
+ | デフォルトの pinentry プログラムは、{{ic|/usr/bin/pinentry-gtk-2}} です。{{Pkg|gtk2}} が使用できない場合、pinentry は{{ic|/usr/bin/pinentry-curses}}にフォールバックし、署名に失敗します。 |
||
+ | |||
+ | gpg: signing failed: Inappropriate ioctl for device |
||
+ | gpg: [stdin]: clear-sign failed: Inappropriate ioctl for device |
||
+ | |||
+ | pinentry プログラム {{ic|/usr/bin/pinentry-tty}} と {{ic|/usr/bin/pinentry-curses}} を使用するには、環境変数 {{ic|GPG_TTY}} を設定する必要があります。 |
||
+ | |||
+ | $ export GPG_TTY=$(tty) |
||
+ | |||
+ | === キーブロックのリソースが存在しません === |
||
+ | |||
+ | 鍵をインポートしようとしたときに、このようなエラーが発生した場合、 |
||
+ | |||
+ | gpg: keyblock resource '''gnupg_home''/pubring.kbx': No such file or directory |
||
+ | |||
+ | これは GnuPG がホームディレクトリを作成しないためです。単に手動で作成してください。 |
||
+ | |||
+ | $ mkdir -m 700 ''gnupg_home'' |
||
== 参照 == |
== 参照 == |
||
* [https://gnupg.org/ GNU Privacy Guard ホームページ] |
* [https://gnupg.org/ GNU Privacy Guard ホームページ] |
||
− | * [https:// |
+ | * [https://futureboy.us/pgp.html Alan Eliasen's GPG Tutorial] |
+ | * [[RFC:4880|RFC 4880]] — "OpenPGP Message Format" |
||
− | * [https://fedoraproject.org/wiki/Creating_GPG_Keys Creating GPG Keys (Fedora)] |
||
+ | * [https://help.riseup.net/en/security/message-security/openpgp/gpg-best-practices gpg.conf recommendations and best practices] |
||
− | * [https://wiki.debian.org/Subkeys OpenPGP subkeys in Debian] |
||
+ | * [[Fedora:Creating GPG Keys]] |
||
− | * [https://sanctum.geek.nz/arabesque/series/gnu-linux-crypto/ 詳しい gpg のチュートリアル] |
||
+ | * [[Debian:Subkeys]] |
||
− | * [https://help.riseup.net/en/security/message-security/openpgp/gpg-best-practices gpg.conf の推奨事項とベストプラクティス] |
||
− | * [https://github.com/ioerror/torbirdy/blob/master/gpg.conf Torbirdy gpg.conf] |
||
− | * [https://www.reddit.com/r/GPGpractice/ /r/GPGpractice - a subreddit to practice using GnuPG] |
||
* [https://github.com/lfit/itpol/blob/master/protecting-code-integrity.md Protecting code integrity with PGP] |
* [https://github.com/lfit/itpol/blob/master/protecting-code-integrity.md Protecting code integrity with PGP] |
||
+ | * [https://sanctum.geek.nz/arabesque/series/gnu-linux-crypto/ A more comprehensive gpg Tutorial] |
||
+ | * [https://www.reddit.com/r/GPGpractice/ /r/GPGpractice - a subreddit to practice using GnuPG.] |
2023年12月28日 (木) 12:55時点における版
公式サイト によれば:
- GnuPG は RFC4880 (別名 PGP) で定義される OpenPGP 標準の完全でフリーな実装です。GnuPG を使うことでデータや通信を暗号化したり署名することができます。多目的の鍵管理システムであり、あらゆる種類の公開鍵ディレクトリのアクセスモジュールです。GnuPG (またの名を GPG) は他のアプリケーションとの簡単に連携できる機能を備えたコマンドラインツールです。豊富なアプリケーションとライブラリが利用可能です。GnuPG のバージョン2は S/MIME と ssh のサポートも含んでいます。
目次
- 1 インストール
- 2 設定
- 3 使い方
- 4 鍵の管理
- 5 署名
- 6 gpg-agent
- 7 スマートカード
- 8 ヒントとテクニック
- 9 トラブルシューティング
- 9.1 Not enough random bytes available
- 9.2 su
- 9.3 エージェントがファイルの終末についてエラーを表示する
- 9.4 KGpg 設定のパーミッション
- 9.5 GNOME on Wayland で SSH エージェントのソケットが上書きされる
- 9.6 mutt
- 9.7 gnupg バージョン 2.1 にアップグレードすると鍵が"消失"する
- 9.8 (鍵を受信しようとすると) どの鍵サーバーでも gpg がフリーズする
- 9.9 スマートカードが検出されない
- 9.10 gpg: WARNING: server 'gpg-agent' is older than us (x < y)
- 9.11 IPC 接続の呼び出しに失敗
- 9.12 汚染された PGP 証明書の軽減
- 9.13 IPC 応答が無効であり、デバイスの ioctl が不適切
- 9.14 キーブロックのリソースが存在しません
- 10 参照
インストール
gnupg をインストールしてください。
gnupg をインストールすると、GnuPG がパスフレーズエントリに使用するシンプルな PIN やパスフレーズエントリダイアログのコレクションである pinentry もインストールされます。シェルスクリプト /usr/bin/pinentry
は #pinentry で説明されている順番で、どの pinentry ダイアログを使用するかを決定します。
グラフィカルフロントエンドや GnuPG と連携するプログラムを使いたい場合はアプリケーション一覧/セキュリティ#暗号化, 署名, ステガノグラフィーを参照してください。
設定
設定ファイルのディレクトリ
GnuPG では $GNUPGHOME
によって全ての設定ファイルを保存するディレクトリが指定されます。デフォルトでは $GNUPGHOME
は設定されておらず、代わりに $HOME
が使われます。そのためインストール直後は ~/.gnupg
ディレクトリが確認できます。スタートアップファイルに次の行を記述することでデフォルト設定を変更できます:
export GNUPGHOME="/path/to/directory"
設定ファイル
デフォルトの設定ファイルは ~/.gnupg/gpg.conf
と ~/.gnupg/dirmngr.conf
です。
デフォルトでは、gnupg ディレクトリのパーミッションは 700 に設定されており、ディレクトリのファイルのパーミッションは 600 に設定されています。ファイルの読み書きやアクセスの権限を持っているのはディレクトリの所有者だけです (r,w,x)。これはセキュリティ上の理由で設定されていることなので変更してはいけません。ディレクトリやファイルがこのセキュリティ対策に従っていない場合、ファイルやホームディレクトリのパーミッションが安全ではないという警告が表示されます。
どんな長いオプションも設定ファイルに追加します。2つのダッシュを書かないで、オプションや必要な引数の名前を書いて下さい。スケルトンファイルは /usr/share/doc/gnupg/
にあります。gpg がなんらかの操作のため最初に起動されたとき、~/.gnupg
が存在しなければこれらのファイルが ~/.gnupg
にコピーされます。#参照 に他の例があります。
また、pacman がパッケージの署名の検証に使用する設定ファイルは別に存在します。詳しくは pacman-key を見てください。
新規ユーザーのデフォルトオプション
新規ユーザーのデフォルトオプションを設定したい場合、/etc/skel/.gnupg/
に設定ファイルを配置してください。新しいユーザーが追加されると、/etc/skel/.gnupg/
から GnuPG のホームディレクトリにファイルがコピーされます。既存のユーザーのために新しい GnuPG ホームディレクトリを作成できる addgnupghome というスクリプトも存在します:
# addgnupghome user1 user2
上記のコマンドは /home/user1/.gnupg
と /home/user2/.gnupg
を作成してスケルトンディレクトリからファイルをコピーします。既に GnuPG のホームディレクトリが存在するユーザーはスキップされます。
使い方
鍵ペアの作成
鍵ペアを生成するにはターミナルに次を入力:
$ gpg --full-gen-key
上記のコマンドを実行すると複数の質問がきかれます。大抵の場合、以下の設定が必要になります:
- RSA (署名のみ) と RSA (暗号化のみ) 鍵。
- 鍵長は2048ビットで十分です。4096ビットを使ったところで "大した効果はありませんし、無駄に時間がかかるようになるだけです" 。
- 副鍵の有効期限の設定は技術的には必須ではありませんが、設定することは悪くありません。標準的なユーザーなら、1年間で十分でしょう。たとえ鍵束へのアクセスを失っても、他の人が有効でないことを知ることができるようになります。鍵を作成した後、新しい鍵を再発行しなくても満了日は延長することができます。
- 名前とメールアドレス。後で同じ鍵に別の識別子を追加できます (複数のメールアドレスが存在する場合など)。
- コメントは必要ありません。コメントフィールドのセマンティクスは 定義があやふや なため、識別子としては限定的です。
- 安全なパスフレーズを選ぶようにしてください (セキュリティ#パスワードの管理を参照)。
鍵一覧
- 公開鍵束の鍵の一覧:
$ gpg --list-keys
- 秘密鍵束の鍵の一覧:
$ gpg --list-secret-keys
公開鍵のエクスポート
公開鍵暗号で交換されたメッセージの機密性を保証するのが gpg の主な利用法です。互いの鍵束の公開鍵を交換して、メッセージを暗号化するときに使用します。秘密鍵は必ず漏洩しないようにしてください。機密性が破れてしまいます。
他の人があなたに暗号化したメッセージを送れるようにするには、彼らがあなたの公開鍵を知っている必要があります。
(メールで送る場合などのために) ASCII 版の公開鍵を public.key
ファイルとして生成するには:
$ gpg --output public.key --armor --export user-id
あるいは、鍵サーバーで鍵を共有する方法もあります。
公開鍵のインポート
メッセージを暗号化して他の人に送るには、彼らの公開鍵が必要です。公開鍵 (public.key
) を自分の公開鍵リングにインポートするには:
$ gpg --import public.key
あるいは、鍵サーバーで公開鍵を見つけます。
特定の Arch Linux パッケージをインストールするためにキー ID をインポートしたい場合は、キーリングの管理 と Makepkg#署名チェック を参照してください。
鍵サーバーを使用する
鍵の送信
自分の公開鍵を公共の PGP 鍵サーバーに登録することで、他の人があなたに直接連絡することなしにあなたの鍵を入手できるようになります:
$ gpg --send-keys user-id
鍵の検索と受信
鍵サーバーの鍵の情報を確認したい場合、次のコマンドを実行:
$ gpg --search-keys user-id
鍵サーバーから鍵をインポートするには:
$ gpg --recv-keys key-id
鍵サーバー
最も一般的な鍵サーバーは次の通りです:
- Ubuntu Keyserver: 分散型、検証なし、キーは削除不可。
- Mailvelope Keyserver: 中央型、E メール ID の検証、キーは削除可能。
- keys.openpgp.org: 中央型、E メール ID の検証、キーは削除可能。サードパーティの署名無し (つまり、Web of Trust のサポートは無し)。
Wikipedia:Key server (cryptographic)#Keyserver examples にその他の鍵サーバもあります。
代替の鍵サーバは、#設定ファイルのうちどれかで keyserver
オプションを使用することによって指定することができます。例えば:
~/.gnupg/dirmngr.conf
keyserver hkp://keyserver.ubuntu.com
いつも使用しているサーバが思うように動かない時に、一時的に別のサーバを使用すると便利です。例えば、以下のようにして別のサーバを使用できます:
$ gpg --keyserver hkps://keys.openpgp.org/ --search-keys user-id
Web Key Directory
Web Key Service (WKS) プロトコルは、鍵配布のための新しい 標準で、電子メールドメインが Web Key Directory (WKD) という独自の鍵サーバーを提供するものです。電子メールアドレス (例 : user@example.com
) に暗号化するとき、GnuPG (>=2.1.16) は、公開鍵をローカル鍵束にまだ持っていなければ、 HTTPS でそのドメイン (example.com
) に照会します。オプション auto-key-locate
は、このメールアドレスのローカル鍵束に鍵がない場合、WKD プロトコルを使って鍵を探します。
# gpg --recipient user@example.org --auto-key-locate --encrypt doc
WKD をサポートしているメールプロバイダーの一覧は GnuPG Wiki を参照してください。メールアドレスのドメインを自分で管理している場合は、このガイドに従って、自分のドメインで WKD を有効にすることができます。あなたの鍵が WKD で見つかるかどうかを確認するには、このウェブインターフェイスが使用できます。
暗号化と復号化
非対称
暗号化や復号化をするときは複数の秘密鍵を使用することが可能です。複数の鍵を使うときは使用する鍵を選択する必要があります。-u <user-id>
オプションや --local-user <user-id>
オプションを使うことで選択できます。このオプションを使うとデフォルトの鍵を使用する代わりに指定された鍵を使用します。先に#鍵の作成が必要です。
(テキストでメッセージをコピー&ペーストするのに適している) ASCII armor を使ってファイルを暗号化するには、次を使用:
$ gpg --encrypt --armor secret.txt
単に暗号化だけしたいときは --armor
は不要です。
ファイルを復号化するには、次のコマンドを使用:
$ gpg --decrypt secret.txt.asc
パスフレーズの入力が求められます。復号化するには送信者の公開鍵をインポートしてある必要があります。
対称
対称暗号化では鍵を生成する必要がなくパスフレーズだけでデータを暗号化できます。対称暗号化を使用するするには --symmetric
または -c
を使用します:
$ gpg -c doc
例:
- パスフレーズを使って対称暗号で
doc
を暗号化。 - AES-256 暗号アルゴリズムを使ってパスフレーズを暗号化。
- SHA-512 ダイジェストアルゴリズムを使ってパスフレーズをハッシュ化。
- 65536回繰り返しパスフレーズをハッシュ化。
$ gpg -c --s2k-cipher-algo AES256 --s2k-digest-algo SHA512 --s2k-count 65536 doc
対称暗号化された doc.gpg
をパスフレーズで復号化して doc
として同じディレクトリに出力するには:
$ gpg --output doc --decrypt doc.gpg
ディレクトリ
ディレクトリの暗号化・復号化は gpgtar(1) で行うことができます。
暗号化:
$ gpgtar -c -o dir.gpg dir
復号化:
$ gpgtar -d dir.gpg
鍵の管理
秘密鍵のバックアップ
秘密鍵をバックアップするには以下を実行:
$ gpg --export-secret-keys --armor <user-id> > privkey.asc
gpg のリリース 2.1 からデフォルトの挙動が変わっており、たとえ鍵の作成時にパスワードを設定しなかった場合でも上記のコマンドを実行したときにパスフレーズによる保護が必須になっています。エクスポートされたファイルを入手してしまえば、パスフレーズを知らなくてもファイルを暗号化したり署名を加えることができてしまうためです。
秘密鍵のバックアップをインポートするには:
$ gpg --import privkey.asc
失効証明書のバックアップ
失効証明書は、新しく生成されたキーに対して自動的に生成されます。これらはデフォルトで ~/.gnupg/openpgp-revocs.d/
にあります。証明書のファイル名は、取り消すキーのフィンガープリントです。
失効証明書は、ユーザーが後で次を使用して手動で生成することもできます。
$ gpg --gen-revoke --armor --output revcert.asc user-id
この証明書は、紛失または侵害された場合に #鍵の取り消し に使用できます。バックアップは、秘密鍵にアクセスできなくなったため、上記のコマンドで新しい失効証明書を生成できない場合に役立ちます。必要に応じて印刷して手で入力できるほど短いです。
鍵の編集
gpg --edit-key <user-id>
コマンドを実行するとメニューが表示され、鍵管理に関連するほとんどの作業を行うことができます。以下は満了日を設定する例です:
$ gpg --edit-key <user-id> > key number > expire yyyy-mm-dd > save > quit
便利なコマンド:
> passwd # change the passphrase > clean # compact any user ID that is no longer usable (e.g revoked or expired) > revkey # revoke a key > addkey # add a subkey to this key > expire # change the key expiration time
- 公開鍵の ASCII バージョンを生成 (例: メールなどで配るため):
$ gpg --armor --output public.key --export <user-id>
- PGP 公開鍵サーバーに鍵を登録して、他の人があなたに直接連絡しなくても鍵を取得できるようにする:
$ gpg --keyserver pgp.mit.edu --send-keys <key-id>
- ユーザー Bob あてに署名と暗号化:
$ gpg -se -r Bob file
- クリアテキスト署名を作成:
$ gpg --clearsign file
副鍵のエクスポート
複数のデバイスで同じ鍵を使い回す場合、マスター鍵を分離させて、セキュリティが低いシステムでは暗号化に必要な副鍵だけを使いたいという状況が考えられます。
まず、エクスポートしたい副鍵を確認してください:
$ gpg -K
エクスポートする副鍵だけを選択:
$ gpg -a --export-secret-subkeys [subkey id]! > /tmp/subkey.gpg
ここで作業を終えても良いですが、パスフレーズの変更もしておくと安全です。一時フォルダに鍵をインポートします:
$ gpg --homedir /tmp/gpg --import /tmp/subkey.gpg $ gpg --homedir /tmp/gpg --edit-key <user-id> > passwd > save $ gpg --homedir /tmp/gpg -a --export-secret-subkeys [subkey id]! > /tmp/subkey.altpass.gpg
これで、他のデバイスで /tmp/subkey.altpass.gpg
を使うことができます。
有効期限の延長
副鍵を設定して一定期間後に満了したら、新しい副鍵を作成できます。他のユーザーが鍵束を更新できるように数週間前に行うようにしましょう。
- 新しい副鍵を作成 (署名と暗号化の鍵の両方)
$ gpg --edit-key <user-id> > addkey
そして質問に答えて下さい (推奨される設定については前のセクションを参照)。
- 変更を保存:
> save
- 鍵サーバーにアップデート:
$ gpg --keyserver pgp.mit.edu --send-keys <user-id>
また、この鍵を複数のコンピュータで使用する場合は、公開鍵(新しい署名付き有効期限付き)をエクスポートして、それらのマシンでインポートすることもできます。
$ gpg --export --output pubkey.gpg user-id $ gpg --import pubkey.gpg
秘密鍵の再エクスポートやバックアップの更新は必要ありません。マスター秘密鍵自体に有効期限がなく、公開鍵やサブ鍵に残された有効期限の署名があればよいのです。
Rotating subkeys
Alternatively, if you prefer to stop using subkeys entirely once they have expired, you can create new ones. Do this a few weeks in advance to allow others to update their keyring.
Create new subkey (repeat for both signing and encrypting key)
$ gpg --edit-key user-id > addkey
And answer the following questions it asks (see #Create a key pair for suggested settings).
Save changes
> save
Update it to a keyserver.
$ gpg --keyserver pgp.mit.edu --send-keys user-id
You will also need to export a fresh copy of your secret keys for backup purposes. See the section #Backup your private key for details on how to do this.
鍵の取り消し
鍵が侵害された、置き換えられた、使用されなくなった、またはパスフレーズを忘れた場合は、キーの取り消しを実行する必要があります。これは、鍵を鍵の失効証明書とマージすることによって行われます。
鍵ペアにアクセスできなくなった場合は、まず#公開鍵のインポートして独自の鍵をインポートします。 次に、キーを失効させるために、#失効証明書のバックアップ で保存したファイルをインポートします。
$ gpg --import revcert.asc
ここで、取り消しを公開する必要があります。 #鍵サーバーを使用するで過去に PGP サーバーを使用したことがある場合は、取り消された鍵を公開 PGP サーバーに送信します。それ以外の場合は、取り消された鍵をファイルにエクスポートし、通信パートナーに配布します。
署名
署名は文章を証明します。文章が改変された場合、署名の検証に失敗します。公開鍵を使用して文章を暗号化する暗号化とは違って、署名はユーザーの秘密鍵を使って作成されます。署名された文章を受け取った人は送り主の公開鍵を使って署名を検証できます。
署名の作成
ファイルに署名する
ファイルに署名するには --sign
または -s
フラグを使います:
$ gpg --output doc.sig --sign doc
上記のコマンドは暗号化も行ってファイルをバイナリ形式で保存します。
ファイルやメッセージにクリア署名
バイナリ形式に圧縮しないでファイルに署名するには:
$ gpg --clearsign doc
上記のコマンドは文章を ASCII-armored 署名でラッピングしますが、文章に変更は加えられません。
分離署名を作成する
文章やファイルとは別に署名ファイルを作成したい場合、--detach-sig
フラグを使ってください:
$ gpg --output doc.sig --detach-sig doc
上記の方法はソフトウェアプロジェクトを配布するときによく用いられます。署名書を検証することで第三者によってファイルが改竄されていないことが確認できます。
署名の検証
署名を検証するには --verify
フラグを使います:
$ gpg --verify doc.sig
doc.sig
は検証したい署名に置き換えてください。
ファイルの検証と復号化を同時に行いたいお場合、--decrypt
フラグを使ってください。
分離署名を検証する場合、ファイルと署名の両方が必要になります。例えば、Arch Linux の ISO を検証する場合:
$ gpg --verify archlinux-version.iso.sig
archlinux-version.iso
が同じディレクトリに存在していなければなりません。
署名の確認
署名を確認するには、--verify
フラグを使用します。
$ gpg --verify doc.sig
ここで doc.sig
は、検証したい署名を含む署名付きファイルです。
分離された署名を検証する場合、署名されたデータファイルと署名ファイルの両方が検証時に存在する必要があります。例えば、Arch Linux の最新の iso を検証する場合、次のようになります。
$ gpg --verify archlinux-version.iso.sig
ここで archlinux-version.iso
は同じディレクトリにある必要があります。
また、第2引数で署名付きデータファイルを指定することも可能です。
$ gpg --verify archlinux-version.iso.sig /path/to/archlinux-version.iso
署名に加えて暗号化されている場合は、復号化を行うだけで署名も検証されます。
gpg-agent
gpg-agent はキーチェインにパスワードをリクエストしたりキャッシュしたりするのに使われるデーモンです。メールクライアントなど外部のプログラムから GnuPG を利用する場合に便利です。gnupg には systemd ユーザーソケットが付属しており、デフォルトで有効になります: gpg-agent.socket
, gpg-agent-extra.socket
, gpg-agent-browser.socket
, gpg-agent-ssh.socket
, dirmngr.socket
。
- gpg はメインの
gpg-agent.socket
を使って gpg-agent デーモンに接続します。 gpg-agent-extra.socket
はリモート環境から Unix ドメインソケットの転送を設定します。秘密鍵をリモート環境に移さなくてもリモート環境で gpg が使えるようになります。詳しくは gpg-agent(1) を参照。- The
gpg-agent-browser.socket
allows web browsers to access the gpg-agent daemon. - SSH は
gpg-agent-ssh.socket
を使って ssh-add プログラムによって追加された SSH 鍵をキャッシュします。必要な設定は #SSH エージェントを見てください。 dirmngr.socket
は鍵サーバーへの接続を処理する GnuPG デーモンを起動します。
設定
gpg-agent は ~/.gnupg/gpg-agent.conf
ファイルで設定することができます。設定オプションは gpg-agent(1) に記載されています。例えば、未使用の鍵の cache ttl を変更することができます:
~/.gnupg/gpg-agent.conf
default-cache-ttl 3600
エージェントのリロード
設定を変更した後は、gpg-connect-agent
でエージェントをリロードしてください:
$ gpg-connect-agent reloadagent /bye
シェルに OK
と出力されます。
しかし、エージェント設定に keep-screen
が追加されている場合など、再起動だけでは十分でないこともあります。
この場合、まず進行中の gpg-agent プロセスを kill してから、上記で説明したように再起動する必要があります。
pinentry
gpg-agent
は pinentry-program
stanza を使用して、パスフレーズの入力を促す際に、特定の pinentry ユーザーインターフェイスを使用するように設定できます。例えば、以下の通りです。
~/.gnupg/gpg-agent.conf
pinentry-program /usr/bin/pinentry-curses
他のも様々な pinentry プログラムがあります。pacman -Ql pinentry | grep /usr/bin/
を参照してください。
変更を行った後は、エージェントのリロードを忘れないでください。
パスワードのキャッシュ
GnuPG のパスワードをセッションの間だけ記憶させたい場合、max-cache-ttl
と default-cache-ttl
を高い値に設定してください:
gpg-agent.conf
max-cache-ttl 60480000 default-cache-ttl 60480000
詳しくは #gpg-agent を参照。
無人のパスフレーズ
GnuPG 2.1.0 から gpg-agent と pinentry の利用が必須になりました。これによって --passphrase-fd 0
コマンドラインオプションによって STDIN からパイプで渡されたパスフレーズの後方互換性が損ねられています。古いリリースと同じような機能を使うには2つのことをする必要があります:
まず、gpg-agent の設定を編集して loopback pinentry モードを許可してください:
~/.gnupg/gpg-agent.conf
allow-loopback-pinentry
gpg-agent プロセスが実行している場合は再起動して変更を適用します。
次に、更新する必要があるアプリケーションに以下のようにコマンドラインパラメータを含めて loopback モードを使用します:
$ gpg --pinentry-mode loopback ...
もしくは、コマンドラインで設定ができない場合、オプションを設定に追加します:
~/.gnupg/gpg.conf
pinentry-mode loopback
SSH エージェント
gpg-agent には OpenSSH エージェントのエミュレーション機能が存在します。既に GnuPG スイートを使っているのであれば、SSH 鍵をキャッシュするのに使うことが可能です。さらに、パスフレーズを管理するのに GnuPG エージェントの PIN エントリダイアログを使えます。
SSH_AUTH_SOCK の設定
SSH が ssh-agent の代わりに gpg-agent を使うように SSH_AUTH_SOCK
を設定してください。シェルのタイプに関係なくプロセスが gpg-agent インスタンスを使うようにするには pam_env を使用します:
~/.pam_environment
SSH_AGENT_PID DEFAULT= SSH_AUTH_SOCK DEFAULT="${XDG_RUNTIME_DIR}/gnupg/S.gpg-agent.ssh"
または、Bash を使う場合:
~/.bashrc
unset SSH_AGENT_PID if [ "${gnupg_SSH_AUTH_SOCK_by:-0}" -ne $$ ]; then export SSH_AUTH_SOCK="$(gpgconf --list-dirs agent-ssh-socket)" fi
適切な TTY を使うように pinentry を設定
gpg-agent(1) にあるように、ユーザーを X セッションに切り替えた場合は GPG_TTY も設定して TTY を更新してください。例:
~/.bashrc
# Set GPG TTY export GPG_TTY=$(tty) # Refresh gpg-agent tty in case user switches into an X session gpg-connect-agent updatestartuptty /bye >/dev/null
複数の端末を同時に使用し、ssh コマンドを実行した同じ端末から pinentry-curses で gpg-agent がパスフレーズを要求するようにしたい場合、SSH 設定ファイルに以下を追加してください。これにより、ssh コマンドを実行するたびに TTY がリフレッシュされるようになります [6]。
~/.ssh/config
Match host * exec "gpg-connect-agent UPDATESTARTUPTTY /bye"
なお、環境変数 GPG_TTY が設定されていないと動作しません。
SSH 鍵の追加
gpg-agent が起動していれば ssh-agent と同じように ssh-add で鍵を追加できます。追加された鍵は ~/.gnupg/sshcontrol
ファイルに保存されます。パスフレーズが必要になったときは毎回 pinentry ダイアログが表示されます。パスフレーズのキャッシュは ~/.gnupg/gpg-agent.conf
ファイルで制御します。以下の例では gpg-agent で鍵を3時間キャッシュします:
~/.gnupg/gpg-agent.conf
default-cache-ttl-ssh 10800 max-cache-ttl-ssh 10800
SSH 認証に PGP 鍵を使用する
PGP 鍵を SSH 鍵として使うこともできます。鍵のメンテナンスを楽にして SSH 鍵をキーカードに保存できます。認証機能を有効にして鍵を作成する必要があります (#カスタム機能を参照)。SSH 認証に PGP 鍵を使用することで得られる様々な利点があります。
- SSH キーを維持する必要がなくなるため、キーのメンテナンスが削減されます。
- 認証キーをスマートカードに保存する能力。GnuPG はカードが利用可能なときにキーを自動的に検出し、エージェントに追加します(
ssh-add -l
またはssh-add -L
で確認)。キーのコメントは次のようなものであるべきです:openpgp:key-id
またはcardno:card-id
。
GPG/SSH キーの公開キー部分を取得するには、gpg --export-ssh-key gpg-key
を実行します。キーが認証可能であっても、このコマンドが "Unusable public key" で失敗する場合は、!
サフィックスを追加します ([7])。
GPG キーをキーカードに持っていない場合、SSH キーとして認識されるように $GNUPGHOME/sshcontrol
にキーを追加する必要があります。キーがキーカードにある場合、その keygrip は sshcontrol
に暗黙的に追加されます。そうでない場合、次の方法でキーの keygrip を取得します:
$ gpg --list-keys --with-keygrip
sub rsa4096 2018-07-25 [A] Keygrip = 1531C8084D16DC4C36911F1585AF0ACE7AAFD7E7
その後、sshcontrol
をこのように編集します。keygrip を追加するのは一度だけの操作です。追加のキーを追加する場合を除いて、ファイルを再度編集する必要はありません。
$GNUPGHOME/sshcontrol
1531C8084D16DC4C36911F1585AF0ACE7AAFD7E7
スマートカード
GnuPG は、スマートカードリーダとのインターフェイスとして scdaemon を使用します。詳細は scdaemon(1) man ページを参照してください。
GnuPG のみ設定
GnuPG ベース以外のカードを使う予定がない場合は、~/.gnupg/scdaemon.conf
の reader-port
パラメータを確認してください。'0' が最初に利用できるシリアルポートリーダーを、'32768' (デフォルト) が最初の USB リーダーを示しています。
GnuPG と pcscd (PCSC Lite)
pcscd(8) は、スマートカードへのアクセスを管理するデーモンです (SCard API)。(GnuPG の内臓の CCID サポートを使うなどして) GnuPG の scdaemon でスマートカードと直接接続できない場合、このデーモンは PCSC Lite ドライバを使用するスマートカードを見つけようとします。
pscsd を使うには、pcsclite と ccid をインストールしてください。そして、pcscd.service
を開始し、(このサービスを永続的に使用する場合は) 有効化してください。あるいは、pcscd.socket
を開始/有効化することで、必要なときにだけデーモンをアクティブ化させることもできます。
常に pcscd を使う
opensc ドライバを使用するスマートカード (一部の国々の ID カードがこれに該当します) を使う場合は、GnuPG の設定に注意する必要があります。特に設定しないと、gpg --card-status
を実行した時に以下のようなメッセージが表示されるかもしれません:
gpg: selecting openpgp failed: ec=6.108
デフォルトでは、scdaemon はデバイスに直接接続しようとします。カードリーダが他のプロセスによって使用されている場合、この接続は失敗します。例えば、pcscd デーモンが OpenSC によって使用されている場合などです。この問題を解決するには、scdaemon と opensc が互いにうまく機能するようにするために、opensc のものと同じドライバを使用する必要があります。scdaemon が pcscd を使用するようにするには、~/.gnupg/scdaemon.conf
から reader-port
を削除し、libpcsclite.so
ライブラリへのパスを指定し、pcscd を確実に使用させるために ccid を無効化する必要があります:
~/.gnupg/scdaemon.conf
pcsc-driver /usr/lib/libpcsclite.so card-timeout 5 disable-ccid
OpenSC を使用しない場合は、scdaemon(1) を確認してください。
pcscd との共有アクセス
GnuPG scdaemon
is the only popular pcscd
client that uses PCSC_SHARE_EXCLUSIVE
flag when connecting to pcscd
. Other clients like OpenSC PKCS#11 that are used by browsers and programs listed in Electronic identification are using PCSC_SHARE_SHARED
that allows simultaneous access to single smartcard. pcscd
will not give exclusive access to smartcard while there are other clients connected. This means that to use GnuPG smartcard features you must before have to close all your open browser windows or do some other inconvenient operations. Starting from version 2.2.28 LTS and 2.3.0 you can enable shared access by modifying your scdaemon.conf
file and adding pcsc-shared
line end of it.
マルチアプレットスマートカード
When using YubiKeys or other multi applet USB dongles with OpenSC PKCS#11 may run into problems where OpenSC switches your Yubikey from OpenPGP to PIV applet, breaking the scdaemon
.
You can hack around the problem by forcing OpenSC to also use the OpenPGP applet. Open /etc/opensc.conf
file, search for Yubikey and change the driver = "PIV-II";
line to driver = "openpgp";
. If there is no such entry, use pcsc_scan
. Search for the Answer to Reset ATR: 12 34 56 78 90 AB CD ...
. Then create a new entry.
/etc/opensc.conf
... card_atr 12:23:34:45:67:89:ab:cd:... { name = "YubiKey Neo"; driver = "openpgp" } ...
After that you can test with pkcs11-tool -O --login
that the OpenPGP applet is selected by default. Other PKCS#11 clients like browsers may need to be restarted for that change to be applied.
SSH 経由でリモートクライアント上のスマートカードを使用する
If you log into a machine via SSH and try to use an attached device via pcscd, you will notice errors such as:
gpg: selecting card failed: No such device gpg: OpenPGP card not available: No such device
This is due to Polkit restricting access to local clients. To fix this, you can add a rule to allow certain users in all cases. The below rule allows all users in the wheel
group to access devices via pcscd
:
/etc/polkit-1/rules.d/99-pcscd.rules
polkit.addRule(function(action, subject) { if (action.id == "org.debian.pcsc-lite.access_card" && subject.isInGroup("wheel")) { return polkit.Result.YES; } }); polkit.addRule(function(action, subject) { if (action.id == "org.debian.pcsc-lite.access_pcsc" && subject.isInGroup("wheel")) { return polkit.Result.YES; } });
After creating the file, make sure to restart polkit.service
.
ヒントとテクニック
他のアルゴリズム
強力なアルゴリズムを使用したい場合:
~/.gnupg/gpg.conf
... personal-digest-preferences SHA512 cert-digest-algo SHA512 default-preference-list SHA512 SHA384 SHA256 SHA224 AES256 AES192 AES CAST5 ZLIB BZIP2 ZIP Uncompressed personal-cipher-preferences TWOFISH CAMELLIA256 AES 3DES
GnuPG の最新版では、デフォルトのアルゴリズムとして SHA256 と AES が使われており、どちらも殆どの場合安全です。しかしながら、2.1 以前の古い GnuPG を使っている場合や、さらに高いセキュリティを求めたい場合、上記のように設定するようにしてください。
パスワードの暗号化
パスワードを暗号化すれば、設定ファイルに平文で書き込まれなくなります。メールのパスワードなどが良い例でしょう。
まずパスワードを記述したファイルを作成してください。パスワードの後に空行を一行だけ追加しておく必要があります。そうしないとファイルを評価するときに gpg がエラーメッセージを返します。
そして次を実行:
$ gpg -e -a -r <user-id> your_password_file
-e
は encrypt、-a
は armor (ASCII 出力)、-r
は受取人のユーザー ID です。
新しく your_password_file.asc
ファイルが作られます。
鍵の無効化
新しい鍵を生成すると無効化証明書が自動的に生成されます。ユーザーが手動で後から生成することも可能です。無効化証明書は ~/.gnupg/openpgp-revocs.d/
に存在します。証明書のファイル名は無効化する鍵のフィンガープリントになります。
鍵を無効化したい場合、無効化証明書をインポートするだけです:
$ gpg --import <fingerprint>.rev
そして鍵サーバーをアップデート:
$ gpg --keyserver subkeys.pgp.net --send-keys <userid>
信頼モデルの変更
デフォルトでは GnuPG は信頼モデルとして Web of Trust を使います。Web of Trust から Trust on First に変更することが可能です。鍵を追加するときに --trust-model=tofu
を追加するか GnuPG の設定ファイルにオプションを追加してください。詳細は GnuPG メーリングリストのメール を参照。
受取人の id を全て隠す
デフォルトでは暗号メッセージには受取人の鍵 ID が含まれます。hidden-recipient <user-id>
を使うことで暗号化するときに ID は削除することが可能です。全ての受取人で ID を削除するには設定ファイルに throw-keyids
を追加してください。この設定によってメッセージの受取人を隠すことができ、トラフィックの解析に対抗することができます (ソーシャルエンジニアリングを使うことでメッセージを復号化できてしまえば誰が受取人なのか確認される可能性があります)。欠点としては、暗号鍵を全て試すことになるので復号化が遅くなります (--try-secret-key <user-id>
)。
キーサインパーティで caff を使う
鍵サーバーやキーリングにある鍵の正当性をユーザーが確認 (つまり鍵の持ち主が本人であることを確認) できるように、PGP/GPG はいわゆる信頼の輪 ("Web of Trust") を利用しています。信頼の輪を維持するために様々なハッカーイベントが開かれており、キーサインパーティはそのひとつです。Zimmermann-Sassaman 鍵署名プロトコルはキーサインパーティを効果的に行うための方式です。こちら にハウツー記事があります。
キーサインパーティの後、鍵に署名したり所有者に署名を送るのを簡略化するために、caff というツールを使うことができます。AUR のパッケージ caff-svnAUR でインストールすることができます。
所有者に署名を送信するには MTA が必要です。MTA を設定していない場合、msmtp をインストールして下さい。
長い ID やフィンガープリントを毎回表示する
長い鍵 ID を表示させるには設定ファイルに keyid-format 0xlong
を追加してください。鍵の指紋を完全に表示するには、設定ファイルに with-fingerprint
を追加してください。
カスタム機能
鍵にカスタム機能を設定することができます。以下の機能を使うことが可能です:
- Certify (マスター鍵のみ) - 副鍵の作成ができるようになります。
- Sign - 公開鍵で検証することができる暗号化署名が作成可能になります。
- Encrypt - 公開鍵でデータを暗号化して、秘密鍵で復号化することができます。
- Authenticate - GnuPG 以外のプログラムで鍵を使って認証できます。SSH 鍵として使用することができるようになります。
マスター鍵の機能は以下のコマンドで指定できます:
$ gpg --full-generate-key --expert
オプションを選択して機能を設定することができます。
副鍵にカスタム機能を指定したい場合、gpg --edit-key
に --expert
フラグを追加してください。詳しくは#鍵の編集を参照。
トラブルシューティング
Not enough random bytes available
鍵を生成するときに、gpg は以下のエラーを表示することがあります:
Not enough random bytes available. Please do some other work to give the OS a chance to collect more entropy!
残っているエントロピーを確認するには、カーネルパラメータをチェックしてください:
$ cat /proc/sys/kernel/random/entropy_avail
エントロピーがたくさんある健康的な Linux 環境ならマックスの 4,096 ビットに近い値が返されます。返ってくる値が 200 以下の場合、システムのエントロピーが足りていません。
エントロピー問題を解決するには、メッセージ通りのことをするのがベストです (例: ディスクを動かす、マウスを動かす、wiki を編集する - 何でもエントロピーの生成に繋がります)。それでも問題が解決しない場合、エントロピーを使い果たしているサービスが何なのかチェックして、しばらくそのサービスを停止してみてください。サービスを停止できない場合、乱数生成#高速な RNG を見て下さい。
su
pinentry
を使う場合、使用するターミナルデバイス (例: /dev/tty1
) の適切なパーミッションが必要です。しかしながら、su (または sudo) を使用すると、所有権は元のユーザーに残り、新しいユーザーにはなくなります。これでは pinentry はたとえ root であっても起動しません。pinentry を使用する (つまりエージェントで gpg を使用する) 前にデバイスのパーミッションを同じ所に変更する必要があります。root で gpg を実行する場合、gpg を使用する直前に所有者を root に変更してください:
# chown root /dev/ttyN # where N is the current tty
そして gpg を使用した後に元に戻して下さい。おそらく /dev/pts/
と同じのが正しいです。
エージェントがファイルの終末についてエラーを表示する
デフォルトの pinentry プログラムは pinentry-gtk-2 であり、D-Bus セッションバスを正しく実行する必要があります。詳しくは一般的なトラブルシューティング#セッションのパーミッションを見て下さい。
もしくは、pinentry-qt
を使うこともできます。#pinentry を参照。
KGpg 設定のパーミッション
kgpg には ~/.gnupg/
のオプションが使えないという問題がありました。非推奨となった options ファイルが原因です。バグ レポートを参照してください。
GNOME on Wayland で SSH エージェントのソケットが上書きされる
Wayland のセッションでは、gnome-session
によって SSH_AUTH_SOCK
が標準の gnome-keyring ソケット $XDG_RUNTIME_DIR/keyring/ssh
に設定されます。このため ~/.pam_environmment
や systemd のユニットファイルで設定した値が上書きされてしまいます。
この挙動を無効化するには GSM_SKIP_AGENT_WORKAROUND
変数を設定してください:
~/.pam_environment
SSH_AGENT_PID DEFAULT= SSH_AUTH_SOCK DEFAULT="${XDG_RUNTIME_DIR}/gnupg/S.gpg-agent.ssh" GSM_SKIP_SSH_AGENT_WORKAROUND DEFAULT="true"
mutt
Mutt は gpg-agent を正しく使用できないため、mutt を使う場合は GPG_AGENT_INFO
環境変数を設定する必要があります (中身は何でもかまいません)。パスワードのキャッシュも有効化してください。
詳しくは フォーラムスレッド を参照してください。
gnupg バージョン 2.1 にアップグレードすると鍵が"消失"する
gpg --list-keys
を実行しても以前まで使っていた鍵が表示されない場合、また、アプリケーションが鍵を見つけられないまたは鍵が不正だとエラーを吐く場合、鍵が新しいフォーマットに移行できていない可能性があります。
GnuPG invalid packet workaround を読んで下さい。要約すると、旧式の pubring.gpg
と secring.gpg
ファイルの鍵にはバグが存在しており、新しい pubring.kbx
ファイルと private-keys-v1.d/
サブディレクトリ、そしてディレクトリのファイルによって置き換えられたということが書かれています。以下のコマンドを実行することで消失した鍵を復旧させることができるかもしれません:
$ cd $ cp -r .gnupg gnupgOLD $ gpg --export-ownertrust > otrust.txt $ gpg --import .gnupg/pubring.gpg $ gpg --import-ownertrust otrust.txt $ gpg --list-keys
(鍵を受信しようとすると) どの鍵サーバーでも gpg がフリーズする
特定の鍵サーバーで鍵を受信しようとして gpg がフリーズしている場合、dirmngr を kill して (問題が起こっていない) 他の鍵サーバーにアクセスできるようにする必要があります。そうしないと全ての鍵サーバーでフリーズしてしまいます。
スマートカードが検出されない
スマートカードにアクセスするための権限がない場合、カードを正しく設定して接続しても、card error
が表示されることがあります。
スマートカードにアクセスする必要があるユーザーに scard
を追加することで解決できます。追加したら、以下のような udev ルールを作って下さい:
/etc/udev/rules.d/71-gnupg-ccid.rules
ACTION=="add", SUBSYSTEM=="usb", ENV{ID_VENDOR_ID}=="1050", ENV{ID_MODEL_ID}=="0116|0111", MODE="660", GROUP="scard"
VENDOR と MODEL は lsusb
の出力にあわせて変更する必要があります。上記は YubikeyNEO の例です。
gpg: WARNING: server 'gpg-agent' is older than us (x < y)
gnupg
をアップグレードしたのに古い gpg-agent が動作し続けていると警告が表示されます。ユーザーの gpg-agent.socket
を再起動してください (再起動するときに --user
フラグを使ってください)。
IPC 接続の呼び出しに失敗
killall gpg-agent dirmngr
と $GNUPGHOME/crls.d/
フォルダの権限が 700
になっていて、gpg-agent
と dirmngr
が起動していないことを確認してください.
デフォルトでは、gnupg パッケージは、ソケットのために /run/user/$UID/gnupg/
ディレクトリを使用します。GnuPG documentation には、このディレクトリが望ましいと書かれています (すべてのファイルシステムがソケットに対応しているわけではありません)。あなたの agent-socket
の設定が、適切なファイルシステムを持つパスを指定しているかどうか確認してください。ic|agent-socket}} のパス設定は、 gpgconf --list-dirs agent-socket
を実行することで確認することができます。
gpg-agent
が正常に起動するか、gpg-agent --daemon
でテストしてください。
汚染された PGP 証明書の軽減
2019 年 6 月、未知の攻撃者が数万(または数十万)の署名を持つ複数の高プロファイル PGP 証明書をスパム送信し(CVE-2019-13050)、これらの署名を SKS 鍵サーバーにアップロードしていました。 これらの汚染された証明書がキーリングに存在すると、gpg は以下のメッセージを表示してハングします。
gpg: removing stale lockfile (created by 7055)
この場合、ブログポストにあるように、汚染された証明書を削除することで軽減できる可能性があります。
IPC 応答が無効であり、デバイスの ioctl が不適切
デフォルトの pinentry プログラムは、/usr/bin/pinentry-gtk-2
です。gtk2 が使用できない場合、pinentry は/usr/bin/pinentry-curses
にフォールバックし、署名に失敗します。
gpg: signing failed: Inappropriate ioctl for device gpg: [stdin]: clear-sign failed: Inappropriate ioctl for device
pinentry プログラム /usr/bin/pinentry-tty
と /usr/bin/pinentry-curses
を使用するには、環境変数 GPG_TTY
を設定する必要があります。
$ export GPG_TTY=$(tty)
キーブロックのリソースが存在しません
鍵をインポートしようとしたときに、このようなエラーが発生した場合、
gpg: keyblock resource 'gnupg_home/pubring.kbx': No such file or directory
これは GnuPG がホームディレクトリを作成しないためです。単に手動で作成してください。
$ mkdir -m 700 gnupg_home