Fixed database keying bug, left db closed causing meta modification fail.

- needed to keep ssl pword a little while longer after rs init

Added more sturdy logic to prevent segv on failed msg/grp meta modification

Added, Data base does not key database if key string is empty

git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@6448 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
chrisparker126 2013-06-20 19:50:25 +00:00
parent 5e319b1261
commit 6b0594dfe1
4 changed files with 36 additions and 22 deletions

View File

@ -1562,12 +1562,12 @@ bool RsGenExchange::processGrpMask(const RsGxsGroupId& grpId, ContentValue &grpC
ok = true; ok = true;
} }
if(grpCv.getAsInt32(RsGeneralDataService::GRP_META_STATUS, value)) if(grpCv.getAsInt32(RsGeneralDataService::GRP_META_STATUS, value) && grpMeta)
{ {
key = RsGeneralDataService::GRP_META_STATUS; key = RsGeneralDataService::GRP_META_STATUS;
currValue = grpMeta->mGroupStatus; currValue = grpMeta->mGroupStatus;
} }
else if(grpCv.getAsInt32(RsGeneralDataService::GRP_META_SUBSCRIBE_FLAG, value)) else if(grpCv.getAsInt32(RsGeneralDataService::GRP_META_SUBSCRIBE_FLAG, value) && grpMeta)
{ {
key = RsGeneralDataService::GRP_META_SUBSCRIBE_FLAG; key = RsGeneralDataService::GRP_META_SUBSCRIBE_FLAG;
currValue = grpMeta->mSubscribeFlags; currValue = grpMeta->mSubscribeFlags;
@ -1575,7 +1575,7 @@ bool RsGenExchange::processGrpMask(const RsGxsGroupId& grpId, ContentValue &grpC
{ {
if(grpMeta) if(grpMeta)
delete grpMeta; delete grpMeta;
return true; return false;
} }
ok &= grpCv.getAsInt32(key+GXS_MASK, mask); ok &= grpCv.getAsInt32(key+GXS_MASK, mask);

View File

@ -32,9 +32,6 @@
#include "serialiser/rstlvkeys.h" #include "serialiser/rstlvkeys.h"
#include "serialiser/rsgxsitems.h" #include "serialiser/rsgxsitems.h"
typedef std::string RsGxsGroupId;
typedef std::string RsGxsMessageId;
class RsGroupMetaData; class RsGroupMetaData;
class RsMsgMetaData; class RsMsgMetaData;

View File

@ -109,6 +109,7 @@ class RsInitConfig
static std::string load_key; static std::string load_key;
static std::string passwd; static std::string passwd;
static std::string gxs_passwd;
static bool autoLogin; /* autoLogin allowed */ static bool autoLogin; /* autoLogin allowed */
static bool startMinimised; /* Icon or Full Window */ static bool startMinimised; /* Icon or Full Window */
@ -163,6 +164,7 @@ std::string RsInitConfig::load_cert;
std::string RsInitConfig::load_key; std::string RsInitConfig::load_key;
std::string RsInitConfig::passwd; std::string RsInitConfig::passwd;
std::string RsInitConfig::gxs_passwd;
//std::string RsInitConfig::gpgPasswd; //std::string RsInitConfig::gpgPasswd;
bool RsInitConfig::autoLogin; /* autoLogin allowed */ bool RsInitConfig::autoLogin; /* autoLogin allowed */
@ -1585,6 +1587,10 @@ int RsInit::LoadCertificates(bool autoLoginNT)
} }
/* wipe out password */ /* wipe out password */
// store pword to allow gxs use it to services' key their databases
// ideally gxs should have its own password
RsInitConfig::gxs_passwd = RsInitConfig::passwd;
RsInitConfig::passwd = ""; RsInitConfig::passwd = "";
create_configinit(RsInitConfig::basedir, RsInitConfig::preferedId); create_configinit(RsInitConfig::basedir, RsInitConfig::preferedId);
@ -2265,7 +2271,7 @@ int RsServer::StartupRetroShare()
// //
mPluginsManager->registerClientServices(pqih) ; mPluginsManager->registerClientServices(pqih) ;
mPluginsManager->registerCacheServices() ; mPluginsManager->registerCacheServices() ;
#define RS_ENABLE_GXS
#ifdef RS_ENABLE_GXS #ifdef RS_ENABLE_GXS
// The idea is that if priorGxsDir is non // The idea is that if priorGxsDir is non
@ -2300,7 +2306,7 @@ int RsServer::StartupRetroShare()
/**** Identity service ****/ /**** Identity service ****/
RsGeneralDataService* gxsid_ds = new RsDataService(currGxsDir + "/", "gxsid_db", RsGeneralDataService* gxsid_ds = new RsDataService(currGxsDir + "/", "gxsid_db",
RS_SERVICE_GXSV2_TYPE_GXSID, NULL, RsInitConfig::passwd); RS_SERVICE_GXSV2_TYPE_GXSID, NULL, RsInitConfig::gxs_passwd);
#ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET #ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET
gxsid_ds->resetDataStore(); gxsid_ds->resetDataStore();
@ -2310,7 +2316,7 @@ int RsServer::StartupRetroShare()
mGxsIdService = new p3IdService(gxsid_ds, NULL); mGxsIdService = new p3IdService(gxsid_ds, NULL);
RsGeneralDataService* gxscircles_ds = new RsDataService(currGxsDir + "/", "gxscircles_db", RsGeneralDataService* gxscircles_ds = new RsDataService(currGxsDir + "/", "gxscircles_db",
RS_SERVICE_GXSV2_TYPE_GXSCIRCLE, NULL, RsInitConfig::passwd); RS_SERVICE_GXSV2_TYPE_GXSCIRCLE, NULL, RsInitConfig::gxs_passwd);
mGxsCircles = new p3GxsCircles(gxscircles_ds, NULL, mGxsIdService); mGxsCircles = new p3GxsCircles(gxscircles_ds, NULL, mGxsIdService);
@ -2339,7 +2345,7 @@ int RsServer::StartupRetroShare()
/**** Photo service ****/ /**** Photo service ****/
RsGeneralDataService* photo_ds = new RsDataService(currGxsDir + "/", "photoV2_db", RsGeneralDataService* photo_ds = new RsDataService(currGxsDir + "/", "photoV2_db",
RS_SERVICE_GXSV2_TYPE_PHOTO, NULL, RsInitConfig::passwd); RS_SERVICE_GXSV2_TYPE_PHOTO, NULL, RsInitConfig::gxs_passwd);
#ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET #ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET
photo_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing photo_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing
@ -2357,7 +2363,7 @@ int RsServer::StartupRetroShare()
RsGeneralDataService* posted_ds = new RsDataService(currGxsDir + "/", "posted_db", RsGeneralDataService* posted_ds = new RsDataService(currGxsDir + "/", "posted_db",
RS_SERVICE_GXSV2_TYPE_POSTED, NULL, RsInitConfig::passwd); RS_SERVICE_GXSV2_TYPE_POSTED, NULL, RsInitConfig::gxs_passwd);
#ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET #ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET
posted_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing posted_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing
@ -2376,7 +2382,7 @@ int RsServer::StartupRetroShare()
RsGeneralDataService* wiki_ds = new RsDataService(currGxsDir + "/", "wiki_db", RsGeneralDataService* wiki_ds = new RsDataService(currGxsDir + "/", "wiki_db",
RS_SERVICE_GXSV2_TYPE_WIKI, RS_SERVICE_GXSV2_TYPE_WIKI,
NULL, RsInitConfig::passwd); NULL, RsInitConfig::gxs_passwd);
#ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET #ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET
wiki_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing wiki_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing
@ -2393,7 +2399,7 @@ int RsServer::StartupRetroShare()
RsGeneralDataService* wire_ds = new RsDataService(currGxsDir + "/", "wire_db", RsGeneralDataService* wire_ds = new RsDataService(currGxsDir + "/", "wire_db",
RS_SERVICE_GXSV2_TYPE_WIRE, NULL, RsInitConfig::passwd); RS_SERVICE_GXSV2_TYPE_WIRE, NULL, RsInitConfig::gxs_passwd);
#ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET #ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET
wire_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing wire_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing
@ -2409,7 +2415,7 @@ int RsServer::StartupRetroShare()
/**** Forum GXS service ****/ /**** Forum GXS service ****/
RsGeneralDataService* gxsforums_ds = new RsDataService(currGxsDir + "/", "gxsforums_db", RsGeneralDataService* gxsforums_ds = new RsDataService(currGxsDir + "/", "gxsforums_db",
RS_SERVICE_GXSV2_TYPE_FORUMS, NULL, RsInitConfig::passwd); RS_SERVICE_GXSV2_TYPE_FORUMS, NULL, RsInitConfig::gxs_passwd);
#ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET #ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET
gxsforums_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing gxsforums_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing
@ -2426,7 +2432,7 @@ int RsServer::StartupRetroShare()
/**** Channel GXS service ****/ /**** Channel GXS service ****/
RsGeneralDataService* gxschannels_ds = new RsDataService(currGxsDir + "/", "gxschannels_db", RsGeneralDataService* gxschannels_ds = new RsDataService(currGxsDir + "/", "gxschannels_db",
RS_SERVICE_GXSV2_TYPE_CHANNELS, NULL, RsInitConfig::passwd); RS_SERVICE_GXSV2_TYPE_CHANNELS, NULL, RsInitConfig::gxs_passwd);
#ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET #ifndef GXS_DEV_TESTNET // NO RESET, OR DUMMYDATA for TESTNET
gxschannels_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing gxschannels_ds->resetDataStore(); //TODO: remove, new service data per RS session, for testing
@ -2448,6 +2454,9 @@ int RsServer::StartupRetroShare()
pqih->addService(gxsforums_ns); pqih->addService(gxsforums_ns);
pqih->addService(gxschannels_ns); pqih->addService(gxschannels_ns);
// remove pword from memory
RsInitConfig::gxs_passwd = "";
#endif // RS_ENABLE_GXS. #endif // RS_ENABLE_GXS.

View File

@ -47,19 +47,27 @@ RetroDb::RetroDb(const std::string &dbPath, int flags, const std::string& key) :
std::cerr << "Can't open database, Error code: " << sqlite3_errmsg(mDb) std::cerr << "Can't open database, Error code: " << sqlite3_errmsg(mDb)
<< std::endl; << std::endl;
sqlite3_close(mDb); sqlite3_close(mDb);
mDb = NULL;
return;
} }
#ifdef ENABLE_ENCRYPTED_DB #ifdef ENABLE_ENCRYPTED_DB
if(!mKey.empty())
{
rc = sqlite3_key(mDb, mKey.c_str(), mKey.size()); rc = sqlite3_key(mDb, mKey.c_str(), mKey.size());
#endif
if(rc){ if(rc){
std::cerr << "Can't key database: " << sqlite3_errmsg(mDb) std::cerr << "Can't key database: " << sqlite3_errmsg(mDb)
<< std::endl; << std::endl;
sqlite3_close(mDb); sqlite3_close(mDb);
mDb = NULL;
return;
} }
} }
#endif
}
RetroDb::~RetroDb(){ RetroDb::~RetroDb(){