From 3364b35064e24ba66e77fae04e1e9d2eeab03194 Mon Sep 17 00:00:00 2001 From: chrisparker126 Date: Tue, 27 Apr 2010 15:39:21 +0000 Subject: [PATCH] Currently the only way to induce a bug is start rs for an ssl_id which which does not have a password saved, then try use an ssl id at start dialog which does or does not have a pword (help_pword:bool enters an illegal state) I have fixed it by checking if rsinit::passwd == "" then trying to load for that ssl_id, if that fails then i set help_pword to false; does not have password and pass flow to gpg to ask for passwd. (problem was rs thought user had help/pass file and they didn't). i have checked it in and tested for 1. starting with ssl_id which has saved pword, and switching ids at start dialog 2. secondary id may or may not have saved pword. git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@2801 b45a01b8-16f6-495d-af2f-9b41ad6348cc --- libretroshare/src/rsserver/rsinit.cc | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/libretroshare/src/rsserver/rsinit.cc b/libretroshare/src/rsserver/rsinit.cc index 73f83510c..ac57bff13 100644 --- a/libretroshare/src/rsserver/rsinit.cc +++ b/libretroshare/src/rsserver/rsinit.cc @@ -1131,7 +1131,14 @@ int RsInit::LoadCertificates(bool autoLoginNT) if(helpFile != NULL){ have_help = true; - fclose(helpFile); + fclose(helpFile); + + if(RsInitConfig::passwd == ""){ // in case user chooses a different user later in setup + RsInitConfig::havePasswd = RsTryAutoLogin(); + have_help = RsInitConfig::havePasswd; + } + + } /* The SSL / SSL + PGP version requires, SSL init + PGP init. */ @@ -1142,7 +1149,7 @@ int RsInit::LoadCertificates(bool autoLoginNT) //check if password is already in memory if (((RsInitConfig::havePasswd) && (RsInitConfig::passwd != "")) && !have_help) { - std::cerr << "RetroShare has a ssl Password" << std::endl; + std::cerr << "RetroShare has an ssl Password" << std::endl; sslPassword = RsInitConfig::passwd.c_str(); std::cerr << "let's store the ssl Password into a pgp ecrypted file" << std::endl;