mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-16 09:57:19 -05:00
use rsReputations instead of rsIdentity for reputation calls. Suspended reputation vetting code which is not needed anymore
This commit is contained in:
parent
8d8453f9c0
commit
a810ae9a74
@ -166,19 +166,17 @@ public:
|
|||||||
|
|
||||||
class GixsReputation
|
class GixsReputation
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
GixsReputation() : score(0) {}
|
GixsReputation() {}
|
||||||
RsGxsId id;
|
|
||||||
int score;
|
RsGxsId id;
|
||||||
|
uint32_t reputation_level ;
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGixsReputation
|
class RsGixsReputation
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
// get Reputation.
|
// get Reputation.
|
||||||
virtual bool haveReputation(const RsGxsId &id) = 0;
|
|
||||||
virtual bool loadReputation(const RsGxsId &id, const std::list<RsPeerId>& peers) = 0;
|
|
||||||
virtual bool getReputation(const RsGxsId &id, GixsReputation &rep) = 0;
|
|
||||||
virtual RsReputations::ReputationLevel overallReputationLevel(const RsGxsId& id) = 0;
|
virtual RsReputations::ReputationLevel overallReputationLevel(const RsGxsId& id) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -186,7 +184,6 @@ public:
|
|||||||
|
|
||||||
class RsGxsIdExchange:
|
class RsGxsIdExchange:
|
||||||
public RsGenExchange,
|
public RsGenExchange,
|
||||||
public RsGixsReputation,
|
|
||||||
public RsGixs
|
public RsGixs
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -3139,6 +3139,9 @@ void RsGxsNetService::runVetting()
|
|||||||
|
|
||||||
RS_STACK_MUTEX(mNxsMutex) ;
|
RS_STACK_MUTEX(mNxsMutex) ;
|
||||||
|
|
||||||
|
#ifdef TO_BE_REMOVED
|
||||||
|
// Author response vetting is disabled since not used, as the reputations are currently not async-ed anymore.
|
||||||
|
|
||||||
std::vector<AuthorPending*>::iterator vit = mPendingResp.begin();
|
std::vector<AuthorPending*>::iterator vit = mPendingResp.begin();
|
||||||
|
|
||||||
for(; vit != mPendingResp.end(); )
|
for(; vit != mPendingResp.end(); )
|
||||||
@ -3169,6 +3172,7 @@ void RsGxsNetService::runVetting()
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// now lets do circle vetting
|
// now lets do circle vetting
|
||||||
|
@ -27,20 +27,13 @@
|
|||||||
#include "pqi/p3servicecontrol.h"
|
#include "pqi/p3servicecontrol.h"
|
||||||
#include "pgp/pgpauxutils.h"
|
#include "pgp/pgpauxutils.h"
|
||||||
|
|
||||||
|
|
||||||
const time_t AuthorPending::EXPIRY_PERIOD_OFFSET = 30; // 30 seconds
|
const time_t AuthorPending::EXPIRY_PERIOD_OFFSET = 30; // 30 seconds
|
||||||
const int AuthorPending::MSG_PEND = 1;
|
const int AuthorPending::MSG_PEND = 1;
|
||||||
const int AuthorPending::GRP_PEND = 2;
|
const int AuthorPending::GRP_PEND = 2;
|
||||||
|
|
||||||
|
AuthorPending::AuthorPending(RsGixsReputation* rep, time_t timeStamp) : mRep(rep), mTimeStamp(timeStamp) {}
|
||||||
|
|
||||||
AuthorPending::AuthorPending(RsGixsReputation* rep, time_t timeStamp)
|
AuthorPending::~AuthorPending() {}
|
||||||
: mRep(rep), mTimeStamp(timeStamp) {
|
|
||||||
}
|
|
||||||
|
|
||||||
AuthorPending::~AuthorPending()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
bool AuthorPending::expired() const
|
bool AuthorPending::expired() const
|
||||||
{
|
{
|
||||||
@ -49,7 +42,12 @@ bool AuthorPending::expired() const
|
|||||||
|
|
||||||
bool AuthorPending::getAuthorRep(GixsReputation& rep, const RsGxsId& authorId, const RsPeerId& peerId)
|
bool AuthorPending::getAuthorRep(GixsReputation& rep, const RsGxsId& authorId, const RsPeerId& peerId)
|
||||||
{
|
{
|
||||||
if(mRep->haveReputation(authorId))
|
rep.id = authorId ;
|
||||||
|
rep.reputation_level = mRep->overallReputationLevel(authorId);
|
||||||
|
|
||||||
|
#warning can it happen that reputations do not have the info yet?
|
||||||
|
return true ;
|
||||||
|
#ifdef TO_BE_REMOVED
|
||||||
{
|
{
|
||||||
return mRep->getReputation(authorId, rep);
|
return mRep->getReputation(authorId, rep);
|
||||||
}
|
}
|
||||||
@ -58,7 +56,7 @@ bool AuthorPending::getAuthorRep(GixsReputation& rep, const RsGxsId& authorId, c
|
|||||||
peers.push_back(peerId);
|
peers.push_back(peerId);
|
||||||
mRep->loadReputation(authorId, peers);
|
mRep->loadReputation(authorId, peers);
|
||||||
return false;
|
return false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
MsgAuthEntry::MsgAuthEntry()
|
MsgAuthEntry::MsgAuthEntry()
|
||||||
@ -98,7 +96,7 @@ bool MsgRespPending::accepted()
|
|||||||
GixsReputation rep;
|
GixsReputation rep;
|
||||||
if(getAuthorRep(rep, entry.mAuthorId, mPeerId))
|
if(getAuthorRep(rep, entry.mAuthorId, mPeerId))
|
||||||
{
|
{
|
||||||
if(rep.score >= mCutOff)
|
if(rep.reputation_level >= mCutOff)
|
||||||
{
|
{
|
||||||
entry.mPassedVetting = true;
|
entry.mPassedVetting = true;
|
||||||
count++;
|
count++;
|
||||||
@ -133,7 +131,7 @@ bool GrpRespPending::accepted()
|
|||||||
|
|
||||||
if(getAuthorRep(rep, entry.mAuthorId, mPeerId))
|
if(getAuthorRep(rep, entry.mAuthorId, mPeerId))
|
||||||
{
|
{
|
||||||
if(rep.score >= mCutOff)
|
if(rep.reputation_level >= mCutOff)
|
||||||
{
|
{
|
||||||
entry.mPassedVetting = true;
|
entry.mPassedVetting = true;
|
||||||
count++;
|
count++;
|
||||||
@ -153,12 +151,12 @@ bool GrpRespPending::accepted()
|
|||||||
|
|
||||||
/** NxsTransaction definition **/
|
/** NxsTransaction definition **/
|
||||||
|
|
||||||
const uint8_t NxsTransaction::FLAG_STATE_STARTING = 0x0001; // when
|
const uint8_t NxsTransaction::FLAG_STATE_STARTING = 0x0001; // when
|
||||||
const uint8_t NxsTransaction::FLAG_STATE_RECEIVING = 0x0002; // begin receiving items for incoming trans
|
const uint8_t NxsTransaction::FLAG_STATE_RECEIVING = 0x0002; // begin receiving items for incoming trans
|
||||||
const uint8_t NxsTransaction::FLAG_STATE_SENDING = 0x0004; // begin sending items for outgoing trans
|
const uint8_t NxsTransaction::FLAG_STATE_SENDING = 0x0004; // begin sending items for outgoing trans
|
||||||
const uint8_t NxsTransaction::FLAG_STATE_COMPLETED = 0x008;
|
const uint8_t NxsTransaction::FLAG_STATE_FAILED = 0x0010;
|
||||||
const uint8_t NxsTransaction::FLAG_STATE_FAILED = 0x0010;
|
|
||||||
const uint8_t NxsTransaction::FLAG_STATE_WAITING_CONFIRM = 0x0020;
|
const uint8_t NxsTransaction::FLAG_STATE_WAITING_CONFIRM = 0x0020;
|
||||||
|
const uint8_t NxsTransaction::FLAG_STATE_COMPLETED = 0x0080; // originaly 0x008, but probably a typo, but we cannot change it since it would break backward compatibility.
|
||||||
|
|
||||||
|
|
||||||
NxsTransaction::NxsTransaction()
|
NxsTransaction::NxsTransaction()
|
||||||
|
@ -171,7 +171,7 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
GXSUTIL_DEBUG() << "TimeStamping group authors' key ID " << grp->metaData->mAuthorId << " in group ID " << grp->grpId << std::endl;
|
GXSUTIL_DEBUG() << "TimeStamping group authors' key ID " << grp->metaData->mAuthorId << " in group ID " << grp->grpId << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(rsIdentity!=NULL && rsIdentity->overallReputationLevel(grp->metaData->mAuthorId) > RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if(rsReputations!=NULL && rsReputations->overallReputationLevel(grp->metaData->mAuthorId) > RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
||||||
used_gxs_ids.insert(std::make_pair(grp->metaData->mAuthorId,RsIdentityUsage(mGenExchangeClient->serviceType(),RsIdentityUsage::GROUP_AUTHOR_KEEP_ALIVE,grp->grpId))) ;
|
used_gxs_ids.insert(std::make_pair(grp->metaData->mAuthorId,RsIdentityUsage(mGenExchangeClient->serviceType(),RsIdentityUsage::GROUP_AUTHOR_KEEP_ALIVE,grp->grpId))) ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -269,7 +269,7 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
#ifdef DEBUG_GXSUTIL
|
#ifdef DEBUG_GXSUTIL
|
||||||
GXSUTIL_DEBUG() << "TimeStamping message authors' key ID " << msg->metaData->mAuthorId << " in message " << msg->msgId << ", group ID " << msg->grpId<< std::endl;
|
GXSUTIL_DEBUG() << "TimeStamping message authors' key ID " << msg->metaData->mAuthorId << " in message " << msg->msgId << ", group ID " << msg->grpId<< std::endl;
|
||||||
#endif
|
#endif
|
||||||
if(rsIdentity!=NULL && rsIdentity->overallReputationLevel(msg->metaData->mAuthorId) > RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if(rsReputations!=NULL && rsReputations->overallReputationLevel(msg->metaData->mAuthorId) > RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
||||||
used_gxs_ids.insert(std::make_pair(msg->metaData->mAuthorId,RsIdentityUsage(mGenExchangeClient->serviceType(),RsIdentityUsage::MESSAGE_AUTHOR_KEEP_ALIVE,msg->metaData->mGroupId,msg->metaData->mMsgId))) ;
|
used_gxs_ids.insert(std::make_pair(msg->metaData->mAuthorId,RsIdentityUsage(mGenExchangeClient->serviceType(),RsIdentityUsage::MESSAGE_AUTHOR_KEEP_ALIVE,msg->metaData->mGroupId,msg->metaData->mMsgId))) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1345,8 +1345,8 @@ int RsServer::StartupRetroShare()
|
|||||||
// create GXS ID service
|
// create GXS ID service
|
||||||
RsGxsNetService* gxsid_ns = new RsGxsNetService(
|
RsGxsNetService* gxsid_ns = new RsGxsNetService(
|
||||||
RS_SERVICE_GXS_TYPE_GXSID, gxsid_ds, nxsMgr,
|
RS_SERVICE_GXS_TYPE_GXSID, gxsid_ds, nxsMgr,
|
||||||
mGxsIdService, mGxsIdService->getServiceInfo(),
|
mGxsIdService, mGxsIdService->getServiceInfo(),
|
||||||
mGxsIdService, mGxsCircles,mGxsIdService,
|
mReputations, mGxsCircles,mGxsIdService,
|
||||||
pgpAuxUtils,
|
pgpAuxUtils,
|
||||||
false,false); // don't synchronise group automatic (need explicit group request)
|
false,false); // don't synchronise group automatic (need explicit group request)
|
||||||
// don't sync messages at all.
|
// don't sync messages at all.
|
||||||
@ -1365,7 +1365,7 @@ int RsServer::StartupRetroShare()
|
|||||||
RsGxsNetService* gxscircles_ns = new RsGxsNetService(
|
RsGxsNetService* gxscircles_ns = new RsGxsNetService(
|
||||||
RS_SERVICE_GXS_TYPE_GXSCIRCLE, gxscircles_ds, nxsMgr,
|
RS_SERVICE_GXS_TYPE_GXSCIRCLE, gxscircles_ds, nxsMgr,
|
||||||
mGxsCircles, mGxsCircles->getServiceInfo(),
|
mGxsCircles, mGxsCircles->getServiceInfo(),
|
||||||
mGxsIdService, mGxsCircles,mGxsIdService,
|
mReputations, mGxsCircles,mGxsIdService,
|
||||||
pgpAuxUtils,
|
pgpAuxUtils,
|
||||||
true, // synchronise group automatic
|
true, // synchronise group automatic
|
||||||
true); // sync messages automatic, since they contain subscription requests.
|
true); // sync messages automatic, since they contain subscription requests.
|
||||||
@ -1384,7 +1384,7 @@ int RsServer::StartupRetroShare()
|
|||||||
RsGxsNetService* posted_ns = new RsGxsNetService(
|
RsGxsNetService* posted_ns = new RsGxsNetService(
|
||||||
RS_SERVICE_GXS_TYPE_POSTED, posted_ds, nxsMgr,
|
RS_SERVICE_GXS_TYPE_POSTED, posted_ds, nxsMgr,
|
||||||
mPosted, mPosted->getServiceInfo(),
|
mPosted, mPosted->getServiceInfo(),
|
||||||
mGxsIdService, mGxsCircles,mGxsIdService,
|
mReputations, mGxsCircles,mGxsIdService,
|
||||||
pgpAuxUtils);
|
pgpAuxUtils);
|
||||||
|
|
||||||
mPosted->setNetworkExchangeService(posted_ns) ;
|
mPosted->setNetworkExchangeService(posted_ns) ;
|
||||||
@ -1420,7 +1420,7 @@ int RsServer::StartupRetroShare()
|
|||||||
RsGxsNetService* gxsforums_ns = new RsGxsNetService(
|
RsGxsNetService* gxsforums_ns = new RsGxsNetService(
|
||||||
RS_SERVICE_GXS_TYPE_FORUMS, gxsforums_ds, nxsMgr,
|
RS_SERVICE_GXS_TYPE_FORUMS, gxsforums_ds, nxsMgr,
|
||||||
mGxsForums, mGxsForums->getServiceInfo(),
|
mGxsForums, mGxsForums->getServiceInfo(),
|
||||||
mGxsIdService, mGxsCircles,mGxsIdService,
|
mReputations, mGxsCircles,mGxsIdService,
|
||||||
pgpAuxUtils);
|
pgpAuxUtils);
|
||||||
|
|
||||||
mGxsForums->setNetworkExchangeService(gxsforums_ns) ;
|
mGxsForums->setNetworkExchangeService(gxsforums_ns) ;
|
||||||
@ -1436,7 +1436,7 @@ int RsServer::StartupRetroShare()
|
|||||||
RsGxsNetService* gxschannels_ns = new RsGxsNetService(
|
RsGxsNetService* gxschannels_ns = new RsGxsNetService(
|
||||||
RS_SERVICE_GXS_TYPE_CHANNELS, gxschannels_ds, nxsMgr,
|
RS_SERVICE_GXS_TYPE_CHANNELS, gxschannels_ds, nxsMgr,
|
||||||
mGxsChannels, mGxsChannels->getServiceInfo(),
|
mGxsChannels, mGxsChannels->getServiceInfo(),
|
||||||
mGxsIdService, mGxsCircles,mGxsIdService,
|
mReputations, mGxsCircles,mGxsIdService,
|
||||||
pgpAuxUtils);
|
pgpAuxUtils);
|
||||||
|
|
||||||
mGxsChannels->setNetworkExchangeService(gxschannels_ns) ;
|
mGxsChannels->setNetworkExchangeService(gxschannels_ns) ;
|
||||||
|
@ -435,10 +435,10 @@ void p3GxsReputation::cleanup()
|
|||||||
|
|
||||||
for(std::map<RsGxsId,Reputation>::iterator it(mReputations.begin());it!=mReputations.end();++it)
|
for(std::map<RsGxsId,Reputation>::iterator it(mReputations.begin());it!=mReputations.end();++it)
|
||||||
{
|
{
|
||||||
bool is_a_contact = rsIdentity->isARegularContact(*it) ;
|
bool is_a_contact = rsIdentity->isARegularContact(it->first) ;
|
||||||
|
|
||||||
if(mAutoSetPositiveOptionToContacts && is_a_contact && it->second.mOwnOpinion == RsReputations::OPINION_NEUTRAL)
|
if(mAutoSetPositiveOptionToContacts && is_a_contact && it->second.mOwnOpinion == RsReputations::OPINION_NEUTRAL)
|
||||||
should_set_to_positive.push_back(*rit) ;
|
should_set_to_positive.push_back(it->first) ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ static const uint32_t REPUTATION_IDENTITY_FLAG_PGP_KNOWN = 0x0002;
|
|||||||
|
|
||||||
#include "retroshare/rsidentity.h"
|
#include "retroshare/rsidentity.h"
|
||||||
#include "retroshare/rsreputations.h"
|
#include "retroshare/rsreputations.h"
|
||||||
|
#include "gxs/rsgixs.h"
|
||||||
#include "services/p3service.h"
|
#include "services/p3service.h"
|
||||||
|
|
||||||
|
|
||||||
@ -100,7 +101,7 @@ public:
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class p3GxsReputation: public p3Service, public p3Config, public RsReputations /* , public pqiMonitor */
|
class p3GxsReputation: public p3Service, public p3Config, public RsGixsReputation, public RsReputations /* , public pqiMonitor */
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
p3GxsReputation(p3LinkMgr *lm);
|
p3GxsReputation(p3LinkMgr *lm);
|
||||||
|
@ -1030,6 +1030,7 @@ bool p3IdService::decryptData(const uint8_t *encrypted_data,uint32_t encrypted_d
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef TO_BE_REMOVED
|
||||||
/********************************************************************************/
|
/********************************************************************************/
|
||||||
/******************* RsGixsReputation ***************************************/
|
/******************* RsGixsReputation ***************************************/
|
||||||
/********************************************************************************/
|
/********************************************************************************/
|
||||||
@ -1083,6 +1084,7 @@ bool p3IdService::getReputation(const RsGxsId &id, GixsReputation &rep)
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
class RegistrationRequest
|
class RegistrationRequest
|
||||||
|
@ -303,9 +303,11 @@ public:
|
|||||||
/**************** RsGixsReputation Implementation ****************/
|
/**************** RsGixsReputation Implementation ****************/
|
||||||
|
|
||||||
// get Reputation.
|
// get Reputation.
|
||||||
|
#ifdef TO_BE_REMOVED
|
||||||
virtual bool haveReputation(const RsGxsId &id);
|
virtual bool haveReputation(const RsGxsId &id);
|
||||||
virtual bool loadReputation(const RsGxsId &id, const std::list<RsPeerId>& peers);
|
virtual bool loadReputation(const RsGxsId &id, const std::list<RsPeerId>& peers);
|
||||||
virtual bool getReputation(const RsGxsId &id, GixsReputation &rep);
|
virtual bool getReputation(const RsGxsId &id, GixsReputation &rep);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -110,14 +110,14 @@ void GxsIdRSTreeWidgetItem::setId(const RsGxsId &id, int column, bool retryWhenF
|
|||||||
|
|
||||||
void GxsIdRSTreeWidgetItem::updateBannedState()
|
void GxsIdRSTreeWidgetItem::updateBannedState()
|
||||||
{
|
{
|
||||||
if(mBannedState != (rsIdentity->overallReputationLevel(mId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE))
|
if(mBannedState != (rsReputations->overallReputationLevel(mId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE))
|
||||||
forceUpdate() ;
|
forceUpdate() ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void GxsIdRSTreeWidgetItem::forceUpdate()
|
void GxsIdRSTreeWidgetItem::forceUpdate()
|
||||||
{
|
{
|
||||||
mIdFound = false;
|
mIdFound = false;
|
||||||
mBannedState = (rsIdentity->overallReputationLevel(mId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE);
|
mBannedState = (rsReputations->overallReputationLevel(mId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE);
|
||||||
|
|
||||||
startProcess();
|
startProcess();
|
||||||
}
|
}
|
||||||
@ -163,7 +163,7 @@ QVariant GxsIdRSTreeWidgetItem::data(int column, int role) const
|
|||||||
|
|
||||||
if(mId.isNull())
|
if(mId.isNull())
|
||||||
return RSTreeWidgetItem::data(column, role);
|
return RSTreeWidgetItem::data(column, role);
|
||||||
else if(rsIdentity->overallReputationLevel(mId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
else if(rsReputations->overallReputationLevel(mId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
||||||
pix = QImage(BANNED_IMAGE) ;
|
pix = QImage(BANNED_IMAGE) ;
|
||||||
else if (mAvatar.mSize == 0 || !pix.loadFromData(mAvatar.mData, mAvatar.mSize, "PNG"))
|
else if (mAvatar.mSize == 0 || !pix.loadFromData(mAvatar.mData, mAvatar.mSize, "PNG"))
|
||||||
pix = GxsIdDetails::makeDefaultIcon(mId);
|
pix = GxsIdDetails::makeDefaultIcon(mId);
|
||||||
|
@ -1546,7 +1546,7 @@ void GxsForumThreadWidget::insertMessageData(const RsGxsForumMsg &msg)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t overall_reputation = rsIdentity->overallReputationLevel(msg.mMeta.mAuthorId) ;
|
uint32_t overall_reputation = rsReputations->overallReputationLevel(msg.mMeta.mAuthorId) ;
|
||||||
bool redacted = (overall_reputation == RsReputations::REPUTATION_LOCALLY_NEGATIVE) ;
|
bool redacted = (overall_reputation == RsReputations::REPUTATION_LOCALLY_NEGATIVE) ;
|
||||||
|
|
||||||
mStateHelper->setActive(mTokenTypeMessageData, true);
|
mStateHelper->setActive(mTokenTypeMessageData, true);
|
||||||
|
Loading…
Reference in New Issue
Block a user