mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-16 09:57:19 -05:00
* Enabled pgphash background work.
* Fixed lots of little bugs: ServiceString decoding, not saving to variables, etc. * Added createIdentity fns. - Can create Anon, but not PGPLinked ones yet? no idea why. * Added lots more debugging. * Added mutex protection for class variables. git-svn-id: http://svn.code.sf.net/p/retroshare/code/branches/v0.5-gxs-b1@5789 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
aebd08f106
commit
0327b47ccc
libretroshare/src
@ -181,8 +181,9 @@ class RsIdOpinion
|
|||||||
class RsIdentityParameters
|
class RsIdentityParameters
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
RsIdentityParameters(): isPgpLinked(false) { return; }
|
||||||
int IdType;
|
bool isPgpLinked;
|
||||||
|
std::string nickname;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -86,6 +86,7 @@ p3IdService::p3IdService(RsGeneralDataService *gds, RsNetworkExchangeService *ne
|
|||||||
mCacheLoad_Status = 0;
|
mCacheLoad_Status = 0;
|
||||||
|
|
||||||
mHashPgp_SearchActive = false;
|
mHashPgp_SearchActive = false;
|
||||||
|
mHashPgp_LastTs = 0;
|
||||||
|
|
||||||
mBgSchedule_Mode = 0;
|
mBgSchedule_Mode = 0;
|
||||||
mBgSchedule_Active = false;
|
mBgSchedule_Active = false;
|
||||||
@ -105,7 +106,7 @@ void p3IdService::service_tick()
|
|||||||
cachetest_tick();
|
cachetest_tick();
|
||||||
|
|
||||||
// background stuff.
|
// background stuff.
|
||||||
//scheduling_tick();
|
scheduling_tick();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -146,7 +147,21 @@ bool p3IdService::submitOpinion(uint32_t& token, RsIdOpinion &opinion)
|
|||||||
|
|
||||||
bool p3IdService::createIdentity(uint32_t& token, RsIdentityParameters ¶ms)
|
bool p3IdService::createIdentity(uint32_t& token, RsIdentityParameters ¶ms)
|
||||||
{
|
{
|
||||||
return false;
|
|
||||||
|
RsGxsIdGroup id;
|
||||||
|
|
||||||
|
id.mMeta.mGroupName = params.nickname;
|
||||||
|
if (params.isPgpLinked)
|
||||||
|
{
|
||||||
|
id.mMeta.mGroupFlags = RSGXSID_GROUPFLAG_REALID;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
id.mMeta.mGroupFlags = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
createGroup(token, id);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -241,11 +256,21 @@ bool p3IdService::getGroupData(const uint32_t &token, std::vector<RsGxsIdGroup>
|
|||||||
{
|
{
|
||||||
group.mPgpKnown = ssdata.pgp.idKnown;
|
group.mPgpKnown = ssdata.pgp.idKnown;
|
||||||
group.mPgpId = ssdata.pgp.pgpId;
|
group.mPgpId = ssdata.pgp.pgpId;
|
||||||
|
|
||||||
|
std::cerr << "p3IdService::getGroupData() Success decoding ServiceString";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
std::cerr << "\t mGpgKnown: " << group.mPgpKnown;
|
||||||
|
std::cerr << std::endl;
|
||||||
|
std::cerr << "\t mGpgId: " << group.mPgpId;
|
||||||
|
std::cerr << std::endl;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
group.mPgpKnown = false;
|
group.mPgpKnown = false;
|
||||||
group.mPgpId = "";
|
group.mPgpId = "";
|
||||||
|
|
||||||
|
std::cerr << "p3IdService::getGroupData() Failed to decode ServiceString";
|
||||||
|
std::cerr << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
groups.push_back(group);
|
groups.push_back(group);
|
||||||
@ -396,7 +421,7 @@ bool SSGxsIdGroup::load(const std::string &input)
|
|||||||
char repstr[RSGXSID_MAX_SERVICE_STRING];
|
char repstr[RSGXSID_MAX_SERVICE_STRING];
|
||||||
|
|
||||||
// split into two parts.
|
// split into two parts.
|
||||||
if (4 != sscanf(input.c_str(), "v1 {%[^}]} {%[^}]} {%[^}]} {%[^}]}", pgpstr, scorestr, opinionstr, repstr))
|
if (4 != sscanf(input.c_str(), "v1 {P:%[^}]} {Y:%[^}]} {O:%[^}]} {R:%[^}]}", pgpstr, scorestr, opinionstr, repstr))
|
||||||
{
|
{
|
||||||
std::cerr << "SSGxsIdGroup::load() Failed to extract 4 Parts";
|
std::cerr << "SSGxsIdGroup::load() Failed to extract 4 Parts";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
@ -404,11 +429,10 @@ bool SSGxsIdGroup::load(const std::string &input)
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
if (0 == strncmp(pgpstr, "P:", 2))
|
if (pgp.load(pgpstr))
|
||||||
{
|
{
|
||||||
std::cerr << "SSGxsIdGroup::load() pgpstr: " << pgpstr;
|
std::cerr << "SSGxsIdGroup::load() pgpstr: " << pgpstr;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
ok &= pgp.load(pgpstr);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -417,11 +441,10 @@ bool SSGxsIdGroup::load(const std::string &input)
|
|||||||
ok = false;
|
ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0 == strncmp(scorestr, "Y:", 2))
|
if (score.load(scorestr))
|
||||||
{
|
{
|
||||||
std::cerr << "SSGxsIdGroup::load() scorestr: " << scorestr;
|
std::cerr << "SSGxsIdGroup::load() scorestr: " << scorestr;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
ok &= score.load(scorestr);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -430,11 +453,10 @@ bool SSGxsIdGroup::load(const std::string &input)
|
|||||||
ok = false;
|
ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0 == strncmp(opinionstr, "O:", 2))
|
if (opinion.load(opinionstr))
|
||||||
{
|
{
|
||||||
std::cerr << "SSGxsIdGroup::load() opinionstr: " << opinionstr;
|
std::cerr << "SSGxsIdGroup::load() opinionstr: " << opinionstr;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
ok &= opinion.load(opinionstr);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -443,11 +465,10 @@ bool SSGxsIdGroup::load(const std::string &input)
|
|||||||
ok = false;
|
ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0 == strncmp(repstr, "R:", 2))
|
if (reputation.load(repstr))
|
||||||
{
|
{
|
||||||
std::cerr << "SSGxsIdGroup::load() repstr: " << repstr;
|
std::cerr << "SSGxsIdGroup::load() repstr: " << repstr;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
ok &= reputation.load(repstr);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -456,6 +477,11 @@ bool SSGxsIdGroup::load(const std::string &input)
|
|||||||
ok = false;
|
ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::cerr << "SSGxsIdGroup::load() regurgitated: " << save();
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
|
std::cerr << "SSGxsIdGroup::load() isOkay?: " << ok;
|
||||||
|
std::cerr << std::endl;
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -479,8 +505,8 @@ std::string SSGxsIdGroup::save() const
|
|||||||
output += reputation.save();
|
output += reputation.save();
|
||||||
output += "}";
|
output += "}";
|
||||||
|
|
||||||
std::cerr << "SSGxsIdGroup::save() output: " << output;
|
//std::cerr << "SSGxsIdGroup::save() output: " << output;
|
||||||
std::cerr << std::endl;
|
//std::cerr << std::endl;
|
||||||
|
|
||||||
return output;
|
return output;
|
||||||
}
|
}
|
||||||
@ -963,15 +989,22 @@ bool p3IdService::cachetest_request()
|
|||||||
|
|
||||||
int p3IdService::scheduling_tick()
|
int p3IdService::scheduling_tick()
|
||||||
{
|
{
|
||||||
std::cerr << "p3IdService::scheduling_tick()";
|
//std::cerr << "p3IdService::scheduling_tick()";
|
||||||
std::cerr << std::endl;
|
//std::cerr << std::endl;
|
||||||
|
|
||||||
/*** MUTEX TODO ***/
|
/*** MUTEX TODO ***/
|
||||||
|
bool active;
|
||||||
|
uint32_t mode;
|
||||||
|
{
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
|
active = mBgSchedule_Active;
|
||||||
|
mode = mBgSchedule_Mode;
|
||||||
|
}
|
||||||
|
|
||||||
if (mBgSchedule_Active)
|
if (active)
|
||||||
{
|
{
|
||||||
bool done = false;
|
bool done = false;
|
||||||
if (mBgSchedule_Mode == BG_PGPHASH)
|
if (mode == BG_PGPHASH)
|
||||||
{
|
{
|
||||||
done = pgphash_continue();
|
done = pgphash_continue();
|
||||||
}
|
}
|
||||||
@ -982,6 +1015,7 @@ int p3IdService::scheduling_tick()
|
|||||||
|
|
||||||
if (done)
|
if (done)
|
||||||
{
|
{
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
mBgSchedule_Active = false;
|
mBgSchedule_Active = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -989,11 +1023,13 @@ int p3IdService::scheduling_tick()
|
|||||||
{
|
{
|
||||||
if (pgphash_start())
|
if (pgphash_start())
|
||||||
{
|
{
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
mBgSchedule_Mode = BG_PGPHASH;
|
mBgSchedule_Mode = BG_PGPHASH;
|
||||||
mBgSchedule_Active = true;
|
mBgSchedule_Active = true;
|
||||||
}
|
}
|
||||||
else if (reputation_start())
|
else if (reputation_start())
|
||||||
{
|
{
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
mBgSchedule_Mode = BG_REPUTATION;
|
mBgSchedule_Mode = BG_REPUTATION;
|
||||||
mBgSchedule_Active = true;
|
mBgSchedule_Active = true;
|
||||||
}
|
}
|
||||||
@ -1043,6 +1079,31 @@ void p3IdService::service_CreateGroup(RsGxsGrpItem* grpItem, RsTlvSecurityKeySet
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/********************* TEMP HACK UNTIL GXS FILLS IN GROUP_ID *****************/
|
||||||
|
// find private admin key
|
||||||
|
std::map<std::string, RsTlvSecurityKey>::iterator mit = keySet.keys.begin();
|
||||||
|
for(; mit != keySet.keys.end(); mit++)
|
||||||
|
{
|
||||||
|
RsTlvSecurityKey& pk = mit->second;
|
||||||
|
|
||||||
|
if(pk.keyFlags & (RSTLV_KEY_DISTRIB_ADMIN | RSTLV_KEY_TYPE_FULL))
|
||||||
|
{
|
||||||
|
item->group.mMeta.mGroupId = pk.keyId;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(mit == keySet.keys.end())
|
||||||
|
{
|
||||||
|
std::cerr << "p3IdService::service_CreateGroup() ERROR no admin key";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/********************* TEMP HACK UNTIL GXS FILLS IN GROUP_ID *****************/
|
||||||
|
|
||||||
std::cerr << "p3IdService::service_CreateGroup() for : " << item->group.mMeta.mGroupId;
|
std::cerr << "p3IdService::service_CreateGroup() for : " << item->group.mMeta.mGroupId;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
|
|
||||||
@ -1125,7 +1186,15 @@ bool p3IdService::pgphash_start()
|
|||||||
|
|
||||||
bool p3IdService::pgphash_continue()
|
bool p3IdService::pgphash_continue()
|
||||||
{
|
{
|
||||||
if (mHashPgp_SearchActive)
|
std::cerr << "p3IdService::pgphash_continue()";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
bool active;
|
||||||
|
{
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
|
active = mHashPgp_SearchActive;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (active)
|
||||||
{
|
{
|
||||||
pgphash_request();
|
pgphash_request();
|
||||||
}
|
}
|
||||||
@ -1145,18 +1214,26 @@ bool p3IdService::pgphash_getlist()
|
|||||||
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
if (mHashPgp_SearchActive)
|
if (mHashPgp_SearchActive)
|
||||||
{
|
{
|
||||||
std::cerr << "p3IdService::cachetest_getlist() Already active";
|
std::cerr << "p3IdService::pgphash_getlist() Already active";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::cerr << "p3IdService::cachetest_getlist() making request";
|
std::cerr << "p3IdService::pgphash_getlist() making request";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
|
|
||||||
uint32_t ansType = RS_TOKREQ_ANSTYPE_SUMMARY;
|
getPgpIdList();
|
||||||
|
|
||||||
|
// ACTUALLY only need summary - but have written code for data.
|
||||||
|
// Also need to use opts.groupFlags to filter stuff properly to REALID's only.
|
||||||
|
// TODO
|
||||||
|
|
||||||
|
//uint32_t ansType = RS_TOKREQ_ANSTYPE_SUMMARY;
|
||||||
|
uint32_t ansType = RS_TOKREQ_ANSTYPE_DATA;
|
||||||
RsTokReqOptions opts;
|
RsTokReqOptions opts;
|
||||||
opts.mReqType = GXS_REQUEST_TYPE_GROUP_META;
|
//opts.mReqType = GXS_REQUEST_TYPE_GROUP_META;
|
||||||
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_DATA;
|
||||||
uint32_t token = 0;
|
uint32_t token = 0;
|
||||||
|
|
||||||
RsGenExchange::getTokenService()->requestGroupInfo(token, ansType, opts);
|
RsGenExchange::getTokenService()->requestGroupInfo(token, ansType, opts);
|
||||||
@ -1177,6 +1254,9 @@ bool p3IdService::pgphash_request()
|
|||||||
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
if (!mHashPgp_SearchActive)
|
if (!mHashPgp_SearchActive)
|
||||||
{
|
{
|
||||||
|
std::cerr << "p3IdService::pgphash_request() Search Not Active returning false";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
token = mHashPgp_Token;
|
token = mHashPgp_Token;
|
||||||
@ -1213,9 +1293,15 @@ bool p3IdService::pgphash_request()
|
|||||||
|
|
||||||
if(ok)
|
if(ok)
|
||||||
{
|
{
|
||||||
|
std::cerr << "p3IdService::pgphash_request() Have " << groups.size() << " Groups";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
std::vector<RsGxsIdGroup>::iterator vit;
|
std::vector<RsGxsIdGroup>::iterator vit;
|
||||||
for(vit = groups.begin(); vit != groups.end(); vit++)
|
for(vit = groups.begin(); vit != groups.end(); vit++)
|
||||||
{
|
{
|
||||||
|
std::cerr << "p3IdService::pgphash_request() Group Id: " << vit->mMeta.mGroupId;
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
/* Filter based on IdType */
|
/* Filter based on IdType */
|
||||||
if (!(vit->mMeta.mGroupFlags & RSGXSID_GROUPFLAG_REALID))
|
if (!(vit->mMeta.mGroupFlags & RSGXSID_GROUPFLAG_REALID))
|
||||||
{
|
{
|
||||||
@ -1251,19 +1337,26 @@ bool p3IdService::pgphash_request()
|
|||||||
|
|
||||||
if (age < wait_period)
|
if (age < wait_period)
|
||||||
{
|
{
|
||||||
std::cerr << "p3IdService::pgphash_request() discarding Recently Check";
|
std::cerr << "p3IdService::pgphash_request() discarding Recent Check";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if we get here -> then its to be processed */
|
/* if we get here -> then its to be processed */
|
||||||
std::cerr << "p3IdService::cachetest_request() Requested Key Id: " << *vit;
|
std::cerr << "p3IdService::pgphash_request() ToProcess Group: " << vit->mMeta.mGroupId;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
|
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
mGroupsToProcess.push_back(*vit);
|
mGroupsToProcess.push_back(*vit);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::cerr << "p3IdService::pgphash_request() getGroupData ERROR";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1271,13 +1364,22 @@ bool p3IdService::pgphash_request()
|
|||||||
bool p3IdService::pgphash_process()
|
bool p3IdService::pgphash_process()
|
||||||
{
|
{
|
||||||
/* each time this is called - process one Id from mGroupsToProcess */
|
/* each time this is called - process one Id from mGroupsToProcess */
|
||||||
if (mGroupsToProcess.empty())
|
RsGxsIdGroup pg;
|
||||||
{
|
{
|
||||||
return true;
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
}
|
if (mGroupsToProcess.empty())
|
||||||
|
{
|
||||||
|
std::cerr << "p3IdService::pgphash_process() List Empty... Done";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
RsGxsIdGroup pg = mGroupsToProcess.front();
|
pg = mGroupsToProcess.front();
|
||||||
mGroupsToProcess.pop_front();
|
mGroupsToProcess.pop_front();
|
||||||
|
|
||||||
|
std::cerr << "p3IdService::pgphash_process() Popped Group: " << pg.mMeta.mGroupId;
|
||||||
|
std::cerr << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
SSGxsIdGroup ssdata;
|
SSGxsIdGroup ssdata;
|
||||||
ssdata.load(pg.mMeta.mServiceString); // attempt load - okay if fails.
|
ssdata.load(pg.mMeta.mServiceString); // attempt load - okay if fails.
|
||||||
@ -1289,6 +1391,9 @@ bool p3IdService::pgphash_process()
|
|||||||
/* found a match - update everything */
|
/* found a match - update everything */
|
||||||
/* Consistency issues here - what if Reputation was recently updated? */
|
/* Consistency issues here - what if Reputation was recently updated? */
|
||||||
|
|
||||||
|
std::cerr << "p3IdService::pgphash_process() CheckId Success for Group: " << pg.mMeta.mGroupId;
|
||||||
|
std::cerr << " PgpId: " << pgpId.toStdString();
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
/* update */
|
/* update */
|
||||||
ssdata.pgp.idKnown = true;
|
ssdata.pgp.idKnown = true;
|
||||||
@ -1320,6 +1425,9 @@ bool p3IdService::pgphash_process()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
std::cerr << "p3IdService::pgphash_process() No Match for Group: " << pg.mMeta.mGroupId;
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
ssdata.pgp.lastCheckTs = time(NULL);
|
ssdata.pgp.lastCheckTs = time(NULL);
|
||||||
ssdata.pgp.checkAttempts++;
|
ssdata.pgp.checkAttempts++;
|
||||||
}
|
}
|
||||||
@ -1329,8 +1437,7 @@ bool p3IdService::pgphash_process()
|
|||||||
std::string serviceString = ssdata.save();
|
std::string serviceString = ssdata.save();
|
||||||
setGroupServiceString(dummyToken, pg.mMeta.mGroupId, serviceString);
|
setGroupServiceString(dummyToken, pg.mMeta.mGroupId, serviceString);
|
||||||
|
|
||||||
return true;
|
return false; // as there are more items on the queue to process.
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1344,6 +1451,11 @@ bool p3IdService::checkId(const RsGxsIdGroup &grp, PGPIdType &pgpId)
|
|||||||
/* iterate through and check hash */
|
/* iterate through and check hash */
|
||||||
GxsIdPgpHash ans(grp.mPgpIdHash);
|
GxsIdPgpHash ans(grp.mPgpIdHash);
|
||||||
|
|
||||||
|
std::cerr << "\tExpected Answer: " << ans.toStdString();
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
|
|
||||||
std::map<PGPIdType, PGPFingerprintType>::iterator mit;
|
std::map<PGPIdType, PGPFingerprintType>::iterator mit;
|
||||||
for(mit = mPgpFingerprintMap.begin(); mit != mPgpFingerprintMap.end(); mit++)
|
for(mit = mPgpFingerprintMap.begin(); mit != mPgpFingerprintMap.end(); mit++)
|
||||||
{
|
{
|
||||||
@ -1372,6 +1484,7 @@ bool p3IdService::checkId(const RsGxsIdGroup &grp, PGPIdType &pgpId)
|
|||||||
std::cerr << "p3IdService::checkId() ERROR Signature Failed";
|
std::cerr << "p3IdService::checkId() ERROR Signature Failed";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#else
|
#else
|
||||||
|
pgpId = mit->first;
|
||||||
std::cerr << "p3IdService::checkId() Skipping Signature check for now... Hash Okay";
|
std::cerr << "p3IdService::checkId() Skipping Signature check for now... Hash Okay";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
return true;
|
return true;
|
||||||
@ -1396,6 +1509,10 @@ void p3IdService::getPgpIdList()
|
|||||||
std::list<std::string> list;
|
std::list<std::string> list;
|
||||||
AuthGPG::getAuthGPG()->getGPGFilteredList(list);
|
AuthGPG::getAuthGPG()->getGPGFilteredList(list);
|
||||||
|
|
||||||
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
|
|
||||||
|
mPgpFingerprintMap.clear();
|
||||||
|
|
||||||
std::list<std::string>::iterator it;
|
std::list<std::string>::iterator it;
|
||||||
for(it = list.begin(); it != list.end(); it++)
|
for(it = list.begin(); it != list.end(); it++)
|
||||||
{
|
{
|
||||||
@ -1403,6 +1520,9 @@ void p3IdService::getPgpIdList()
|
|||||||
PGPFingerprintType fp;
|
PGPFingerprintType fp;
|
||||||
AuthGPG::getAuthGPG()->getKeyFingerprint(pgpId, fp);
|
AuthGPG::getAuthGPG()->getKeyFingerprint(pgpId, fp);
|
||||||
|
|
||||||
|
std::cerr << "p3IdService::getPgpIdList() Id: " << pgpId.toStdString() << " => " << fp.toStdString();
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
mPgpFingerprintMap[pgpId] = fp;
|
mPgpFingerprintMap[pgpId] = fp;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1423,6 +1543,15 @@ void calcPGPHash(const RsGxsId &id, const PGPFingerprintType &pgp, GxsIdPgpHash
|
|||||||
SHA1_Final(signature, sha_ctx);
|
SHA1_Final(signature, sha_ctx);
|
||||||
hash = GxsIdPgpHash(signature);
|
hash = GxsIdPgpHash(signature);
|
||||||
|
|
||||||
|
std::cerr << "calcPGPHash():";
|
||||||
|
std::cerr << std::endl;
|
||||||
|
std::cerr << "\tRsGxsId: " << id;
|
||||||
|
std::cerr << std::endl;
|
||||||
|
std::cerr << "\tFingerprint: " << pgp.toStdString();
|
||||||
|
std::cerr << std::endl;
|
||||||
|
std::cerr << "\tFinal Hash: " << hash.toStdString();
|
||||||
|
std::cerr << std::endl;
|
||||||
|
|
||||||
delete sha_ctx;
|
delete sha_ctx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1499,7 +1628,7 @@ void p3IdService::generateDummyData()
|
|||||||
createGroup(dummyToken, id);
|
createGroup(dummyToken, id);
|
||||||
|
|
||||||
// LIMIT - AS GENERATION IS BROKEN.
|
// LIMIT - AS GENERATION IS BROKEN.
|
||||||
#define MAX_TEST_GEN 50
|
#define MAX_TEST_GEN 5
|
||||||
if (++genCount > MAX_TEST_GEN)
|
if (++genCount > MAX_TEST_GEN)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user