gpg2: nenhuma chave secreta

21

Estou usando o enigmail há mais de um ano sem problemas e hoje não funciona.

Encontrei o seguinte fato interessante:

gpg --decrypt something.gpg # this works
gpg2 --decrypt something.gpg # this fails

Então, algo está quebrado com a versão 2 do gpg na minha máquina.

Isso me levou a ver que:

gpg --list-secret-keys # reads from ~/.gnupg/secring.gpg
gpg2 --list-secret-keys # reads from ~/.gnupg/pubring.gpg (pubring?!) 

Essa parece ser a raiz do problema ... é claro gpg2que não é possível encontrar a chave secreta porque ela está procurando no arquivo errado.

Como pode minha gpg2falha quando meus gpgtrabalhos funcionam bem? Não vejo nenhuma opção para especificar de onde as chaves secretas são lidas.

Alguém tem alguma ideia?


Resposta a @grawity :

Obrigado, agradeço a sua ajuda. Eu corri stracee vejo o que você está falando.

No entanto, mesmo depois gpg2 --import ...que não vejo diferença no comportamento. Só consigo funcionar se eu reiniciar (sem iniciar o gpg-agent), executar gpg2 --import ...e executar gpg2 --decrypt .... Após essa sequência, o thunderbird + enigmail também se comporta bem. No entanto, após 15 minutos ou mais (meu palpite é que a senha que eu digitei para descriptografar expirou), gpg-agentretornamos ao seu antigo comportamento. Esta sequência é repetível.

Então, aqui estão alguns resultados, se isso ajudar a esclarecer alguma coisa:

saída de gpg2 -K:

/home/<username>/.gnupg/pubring.gpg
---------------------------------
sec   rsa4096/AAAAAAAA <date> [SC]
uid         [ultimate] <description of me>
ssb   rsa4096/BBBBBBBB <date> [E]

saída de gpg-connect-agent

> keyinfo --list
S KEYINFO <keygrip associated with AAAAAAAA> D - - - P - - -
S KEYINFO <keygrip associated with BBBBBBBB> D - - - P - - -
OK

saída de gpg2 -v -r <my email> -e testfile

gpg: using PGP trust model
gpg: using subkey BBBBBBBB instead of primary key AAAAAAAA
gpg: This key belongs to us
gpg: reading from 'testfile'
gpg: writing to 'testfile.gpg'
gpg: RSA/AES256 encrypted for: "BBBBBBBB <description of me>"

saída de gpg2 -v -d testfile.gpg

gpg: public key is BBBBBBBB
gpg: using subkey BBBBBBBB instead of primary key AAAAAAAA
gpg: using subkey BBBBBBBB instead of primary key AAAAAAAA
gpg: encrypted with 4096-bit RSA key, ID BBBBBBBB, created <date>
      "<description of me>"
gpg: public key decryption failed: Operation cancelled
gpg: decryption failed: No secret key
rexroni
fonte
Você acabou resolvendo isso? Estou tendo exatamente o mesmo problema.
Volker
Deixa pra lá, eu consertei. O necessário para usar gpg-agente o programa de pinentry precisavam ser definidos como pinentry-gtk-2. Antes de ser definido como pinentry-gnome3, existia no meu sistema, mas não funcionava. Eu tive que instalar manualmente pinentry-gtk-2.
Volker,

Respostas:

22

… É claro que o gpg2 não consegue encontrar a chave secreta porque está procurando no arquivo errado.

Esse não é o único arquivo que ele está vendo.

No GnuPG 1.x (e 2.0), a "secring" costumava ter uma cópia duplicada dos dados públicos do seu bloqueio de chaves, portanto era totalmente independente (e a única diferença entre gpg -ke gpg -Kqual arquivo seria lido) , mas, ao mesmo tempo, mais difícil para o programa manter.

No GnuPG 2.1, as chaves secretas agora são armazenadas independentemente - elas são mantidas pelo gpg-agent , que as mantém ~/.gnupg/private-keys-v1.d/. Então, ambos gpg -ke gpg -Kagora precisam ler as informações do OpenPGP no pubring, mas o último pergunta adicionalmente ao gpg-agent sobre quais certificados têm chaves secretas associadas. Se você estiver usando strace , deverá notar uma connect()ligação logo após ler o pubring.

Se o GnuPG não migrou automaticamente as chaves, basta importar a seção inteira diretamente:

gpg2 --import ~/.gnupg/secring.gpg

Para verificar o conteúdo do agente manualmente:

$ gpg-connect-agent 
> keyinfo --list
S KEYINFO 926145FFCA32B3E6E079A0CF73EA77C40733A349 D - - - P - - -
S KEYINFO BACFB81EAFC864F4AB2926E8B1F55AD579F78D1A D - - - P - - -
S KEYINFO FF3D1DD51B9C79E148CCCEA5F7F3E25EC96048B7 D - - - P - - -
S KEYINFO 4D29EF1460F164CDB11D0FC0247214660ACDD60F D - - - P - - -
S KEYINFO 06B13685B9AA429B9CABCE480930D74B991C8DF0 D - - - P - - -
S KEYINFO B28DB8D045654E8A6A40466A07FCD9E432935E29 D - - - P - - -
Está bem
> / tchau 
$

Estes são os "keygrips" - compare-os com a seção do GnuPG:

$ gpg --list-secret-keys --with-keygrip
/home/fred/.gnupg/pubring.kbx
--------------------------------
sec ed25519 18/08/2018 [SC]
      2357E133AD5D24F6CB2C1B0CEF4F7ED27E252632
      Keygrip = 4D29EF1460F164CDB11D0FC0247214660ACDD60F 
uid [último] Fred Foobar <[email protected]>
gravidade
fonte
Eu tive o mesmo problema: tentei gerar um nome de usuário chave com o gpg --gen-keyqual queria usar gopass. Infelizmente, gopassusos gpg2... gpg2 --importfuncionou como um encanto! Obrigado!
andiba 7/09/17
Para mim, gpg2 --import ~/.gnupg/pubring.gpgconsertei.
Dilawar
Você é meu heroo
Lo-Tan
1

Eventualmente, eu decidi que o problema era que eu estava usando o Debian Unstable e havia uma incompatibilidade de versão introduzida por um apt-get dist-upgrade. Suponho que é por isso que eles chamam de "Instável".

rexroni
fonte
Eu também o tenho no Ubuntu LTS. Depois de mudar do Ubuntu Unity para o GNOME.
Nerdoc 6/05