gpg-agent dejó de funcionar

4

He estado utilizando con éxito el paquete gnupg21 de MacPorts durante varios meses. En los últimos días actualicé mi instalación de MacPorts ( sudo port -d selfupdate ) y luego me aseguré de que estaba al día ( sudo port upgrade outdated ). Desde entonces, gpgv2 ya no funciona:

tartarus:~ sbooth$ gpg2 -K
gpg: can't connect to the agent: IPC connect call failed

tartarus:~ sbooth$ gpg-connect-agent
gpg-connect-agent: no running gpg-agent - starting '/opt/local/bin/gpg-agent'
gpg-connect-agent: waiting for the agent to come up ... (5s)
gpg-connect-agent: waiting for the agent to come up ... (4s)
gpg-connect-agent: waiting for the agent to come up ... (3s)
gpg-connect-agent: waiting for the agent to come up ... (2s)
gpg-connect-agent: waiting for the agent to come up ... (1s)
gpg-connect-agent: can't connect to the agent: IPC connect call failed
gpg-connect-agent: error sending standard options: No agent running

tartarus:~ sbooth$ gpg-agent --help
Assertion failed: (res == 0), function enter_npth, file npth.c, line 123.
Abort trap: 6

He desinstalado completamente la instalación de mi MacPorts ( rm -rf /opt/local ) y reinstalé todo, sin éxito. ¿Hay algo más que pueda probar?

Estoy ejecutando macOS Sierra 10.12.1 (16B2657).

    
pregunta sbooth 22.11.2016 - 06:52

1 respuesta

4

Estoy viendo exactamente el mismo problema y, según un informe de error de MacPorts , proviene de libgpg-error y no se ve con GnuPG versión 2.1.16.

Parece que tenemos que esperar a que el puerto gnupg21 se mueva de 2.1.15 a 2.1.16 o modifique y reconstruya localmente el puerto gnupg21 (y quizás algunas de sus dependencias) para actualizar antes de la actualización oficial. No estoy seguro de querer hacer esto último con algo como GnuPG, aunque eso es solo una reacción instintiva.

Solución

En lugar de actualizar gnupg21 , he encontrado que degradar libgpg-error hace que el problema desaparezca (lo intenté debido al comentario en las listas publicación de la lista de correo de GnuPG vinculada desde el informe de error que es la actualización de libgpg-error de 1.24 a 1.25 lo que causó el problema) .

MacPorts proporciona orientación sobre la degradación de un puerto y en uno de mis Mac todavía tenía 1.24 disponibles ( Instalé MacPorts sin privilegios de raíz, de ahí la omisión de sudo aquí):

$ port installed inactive | grep libgpg
  libgpg-error @1.24
$ port activate libgpg-error @1.24
--->  Computing dependencies for libgpg-error
--->  Deactivating libgpg-error @1.25_0
--->  Cleaning libgpg-error
--->  Activating libgpg-error @1.24_0
--->  Cleaning libgpg-error
$ port installed inactive | grep libgpg
  libgpg-error @1.25
$ gpg2 -K

No error, much joy :)

No es tan sencillo si la versión anterior se eliminó, pero también funciona para mí (y dada la referencia a los errores de vinculación, sería prudente desinstalar y luego reinstalar gnupg21 después de degradar libgpg-error si se usa el método anterior) :

$ svn checkout -r 150579
https://svn.macports.org/repository/macports/trunk/dports/devel/libgpg-error
Error validating server certificate for 'https://svn.macports.org:443':
 - The certificate is not issued by a trusted authority. Use the
   fingerprint to validate the certificate manually!
Certificate information:
 - Hostname: *.macports.org
 - Valid: from Mar  2 07:47:38 2016 GMT until May  2 01:19:52 2017 GMT
 - Issuer: GlobalSign Domain Validation CA - SHA256 - G2, GlobalSign nv-sa, BE
 - Fingerprint: 3E:AF:D7:EA:81:A4:92:33:B6:BC:DA:38:76:C3:15:54:9A:09:50:E0
(R)eject, accept (t)emporarily or accept (p)ermanently? t
A    libgpg-error/files
A    libgpg-error/files/patch-configure.diff
A    libgpg-error/Portfile
Checked out revision 150579.
$ cd libgpg-error/
$ port install
--->  Computing dependencies for libgpg-error
--->  Fetching distfiles for libgpg-error
--->  Verifying checksums for libgpg-error
--->  Extracting libgpg-error
--->  Applying patches to libgpg-error
--->  Configuring libgpg-error
--->  Building libgpg-error
--->  Staging libgpg-error into destroot
--->  Installing libgpg-error @1.24_0
--->  Deactivating libgpg-error @1.25_0
--->  Cleaning libgpg-error
--->  Activating libgpg-error @1.24_0
--->  Cleaning libgpg-error
--->  Updating database of binaries
--->  Scanning binaries for linking errors
--->  Found 16 broken file(s), matching files to ports
--->  Found 1 broken port(s), determining rebuild order
--->  Rebuilding in order
     gnupg21 @2.1.15 +pinentry_mac
Portfile changed since last build; discarding previous state.
--->  Computing dependencies for gnupg21
--->  Cleaning gnupg21
--->  Scanning binaries for linking errors
--->  Found 16 broken file(s), matching files to ports
--->  Found 1 broken port(s), determining rebuild order
--->  Rebuilding in order
     gnupg21 @2.1.15 +pinentry_mac
--->  Computing dependencies for gnupg21
--->  Fetching distfiles for gnupg21
--->  Verifying checksums for gnupg21
--->  Extracting gnupg21
--->  Configuring gnupg21
--->  Building gnupg21
--->  Staging gnupg21 into destroot
--->  Deactivating gnupg21 @2.1.15_0+pinentry_mac
--->  Cleaning gnupg21
--->  Uninstalling gnupg21 @2.1.15_0+pinentry_mac
--->  Cleaning gnupg21
--->  Computing dependencies for gnupg21
--->  Installing gnupg21 @2.1.15_0+pinentry_mac
--->  Activating gnupg21 @2.1.15_0+pinentry_mac

GPG 2.1 uses a new format for its key files. Therefore you cannot use it together with any earlier version of GPG. Neither can you
easily go back to an older version as the old version cannot read the new format.

--->  Cleaning gnupg21
--->  Updating database of binaries
--->  Scanning binaries for linking errors
--->  No broken files found.
    
respondido por el codebrewer 22.11.2016 - 10:56

Lea otras preguntas en las etiquetas