diff --git a/libretroshare/src/pqi/authgpg.cc b/libretroshare/src/pqi/authgpg.cc index d7103d775..2556681a4 100644 --- a/libretroshare/src/pqi/authgpg.cc +++ b/libretroshare/src/pqi/authgpg.cc @@ -88,7 +88,7 @@ gpg_error_t pgp_pwd_callback(void *hook, const char *uid_hint, const char *passp #endif text = gpg_password_static; } else { - if(prev_was_bad) { + if(prev_was_bad || !AuthGPG::getAuthGPG()->getAutorisePasswordCallbackNotify()) { #ifdef GPG_DEBUG fprintf(stderr, "pgp_pwd_callback() allow only one try to be consistent with gpg agent.\n"); #endif @@ -124,7 +124,7 @@ static char *PgpPassword = NULL; AuthGPG::AuthGPG() - :gpgmeInit(false),gpgmeKeySelected(false),p3Config(CONFIG_TYPE_AUTHGPG) + :gpgmeInit(false),gpgmeKeySelected(false),autorisePasswordCallbackNotify(true),p3Config(CONFIG_TYPE_AUTHGPG) { RsStackMutex stack(pgpMtx); /******* LOCKED ******/ @@ -274,7 +274,7 @@ int AuthGPG::GPGInit(std::string ownId) { RsStackMutex stack(pgpMtx); /******* LOCKED ******/ std::cerr << "AuthGPG::GPGInit() called with own gpg id : " << ownId << std::endl; - + is_set_gpg_password_static= false; if (!gpgmeInit) { return 0; } @@ -2142,3 +2142,12 @@ bool AuthGPG::loadList(std::list load) } return true; } + +void AuthGPG::setAutorisePasswordCallbackNotify(bool autorise) { + autorisePasswordCallbackNotify = autorise; + return; +} + +bool AuthGPG::getAutorisePasswordCallbackNotify() { + return autorisePasswordCallbackNotify; +} diff --git a/libretroshare/src/pqi/authgpg.h b/libretroshare/src/pqi/authgpg.h index 322db7f70..ec01e43b4 100644 --- a/libretroshare/src/pqi/authgpg.h +++ b/libretroshare/src/pqi/authgpg.h @@ -120,6 +120,9 @@ class AuthGPG : public p3Config bool printKeys(); + void setAutorisePasswordCallbackNotify(bool); + bool getAutorisePasswordCallbackNotify(); + /*********************************************************************************/ /************************* STAGE 1 ***********************************************/ /*********************************************************************************/ @@ -239,6 +242,8 @@ private: bool gpgmeInit; bool gpgmeKeySelected; + + bool autorisePasswordCallbackNotify; gpgme_engine_info_t INFO; gpgme_ctx_t CTX; diff --git a/libretroshare/src/rsserver/rsinit.cc b/libretroshare/src/rsserver/rsinit.cc index 855618418..ec519d829 100644 --- a/libretroshare/src/rsserver/rsinit.cc +++ b/libretroshare/src/rsserver/rsinit.cc @@ -824,25 +824,6 @@ bool RsInit::SelectGPGAccount(std::string id) } -//bool RsInit::LoadGPGPassword(std::string inPGPpasswd) -//{ -// -// bool ok = false; -// if (0 < AuthGPG::getAuthGPG() -> LoadGPGPassword(inPGPpasswd)) -// { -// ok = true; -// std::cerr << "PGP LoadPwd Success!"; -// std::cerr << std::endl; -// } -// else -// { -// std::cerr << "PGP LoadPwd Failed!"; -// std::cerr << std::endl; -// } -// return ok; -//} - - bool RsInit::GeneratePGPCertificate(std::string name, std::string email, std::string passwd, std::string &pgpId, std::string &errString) { return AuthGPG::getAuthGPG()->GeneratePGPCertificate(name, email, passwd, pgpId, errString); } @@ -1185,6 +1166,8 @@ int RsInit::LoadCertificates(bool autoLoginNT) /* wipe password */ RsInitConfig::passwd = ""; create_configinit(RsInitConfig::basedir, RsInitConfig::preferedId); + //don't autorise the password callback again because it will lead to deadlock due to QT reentrance + AuthGPG::getAuthGPG()->setAutorisePasswordCallbackNotify(false); return 1; }