mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-13 08:29:32 -05:00
Merge pull request #1478 from G10h4ck/jsonapi
extend JSON API to identities, circles and reputation
This commit is contained in:
commit
f4e13975b0
@ -504,7 +504,7 @@ void IdentityHandler::handleGetIdentityDetails(Request& req, Response& resp)
|
|||||||
|
|
||||||
resp.mDataStream << makeKeyValue("bannned_node", rsReputations->isNodeBanned(data.mPgpId));
|
resp.mDataStream << makeKeyValue("bannned_node", rsReputations->isNodeBanned(data.mPgpId));
|
||||||
|
|
||||||
RsReputations::ReputationInfo info;
|
RsReputationInfo info;
|
||||||
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId), data.mPgpId, info);
|
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId), data.mPgpId, info);
|
||||||
resp.mDataStream << makeKeyValue("friends_positive_votes", info.mFriendsPositiveVotes);
|
resp.mDataStream << makeKeyValue("friends_positive_votes", info.mFriendsPositiveVotes);
|
||||||
resp.mDataStream << makeKeyValue("friends_negative_votes", info.mFriendsNegativeVotes);
|
resp.mDataStream << makeKeyValue("friends_negative_votes", info.mFriendsNegativeVotes);
|
||||||
@ -637,18 +637,12 @@ void IdentityHandler::handleSetOpinion(Request& req, Response& resp)
|
|||||||
int own_opinion;
|
int own_opinion;
|
||||||
req.mStream << makeKeyValueReference("own_opinion", own_opinion);
|
req.mStream << makeKeyValueReference("own_opinion", own_opinion);
|
||||||
|
|
||||||
RsReputations::Opinion opinion;
|
RsOpinion opinion;
|
||||||
switch(own_opinion)
|
switch(own_opinion)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0: opinion = RsOpinion::NEGATIVE; break;
|
||||||
opinion = RsReputations::OPINION_NEGATIVE;
|
case 1: opinion = RsOpinion::NEUTRAL; break;
|
||||||
break;
|
case 2: opinion = RsOpinion::POSITIVE; break;
|
||||||
case 1: opinion =
|
|
||||||
RsReputations::OPINION_NEUTRAL;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
opinion = RsReputations::OPINION_POSITIVE;
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
resp.setFail();
|
resp.setFail();
|
||||||
return;
|
return;
|
||||||
|
@ -136,7 +136,8 @@ bool DistributedChatService::handleRecvChatLobbyMsgItem(RsChatMsgItem *ci)
|
|||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(rsReputations->overallReputationLevel(cli->signature.keyId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( rsReputations->overallReputationLevel(cli->signature.keyId) ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
std::cerr << "(WW) Received lobby msg/item from banned identity " << cli->signature.keyId << ". Dropping it." << std::endl;
|
std::cerr << "(WW) Received lobby msg/item from banned identity " << cli->signature.keyId << ". Dropping it." << std::endl;
|
||||||
return false ;
|
return false ;
|
||||||
@ -677,9 +678,10 @@ void DistributedChatService::handleRecvChatLobbyEventItem(RsChatLobbyEventItem *
|
|||||||
#ifdef DEBUG_CHAT_LOBBIES
|
#ifdef DEBUG_CHAT_LOBBIES
|
||||||
std::cerr << "Received ChatLobbyEvent item of type " << (int)(item->event_type) << ", and string=" << item->string1 << std::endl;
|
std::cerr << "Received ChatLobbyEvent item of type " << (int)(item->event_type) << ", and string=" << item->string1 << std::endl;
|
||||||
#endif
|
#endif
|
||||||
rstime_t now = time(NULL) ;
|
rstime_t now = time(nullptr);
|
||||||
|
|
||||||
if(rsReputations->overallReputationLevel(item->signature.keyId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( rsReputations->overallReputationLevel(item->signature.keyId) ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
std::cerr << "(WW) Received lobby msg/item from banned identity " << item->signature.keyId << ". Dropping it." << std::endl;
|
std::cerr << "(WW) Received lobby msg/item from banned identity " << item->signature.keyId << ". Dropping it." << std::endl;
|
||||||
return ;
|
return ;
|
||||||
|
@ -2014,7 +2014,8 @@ bool p3GRouter::verifySignedDataItem(RsGRouterAbstractMsgItem *item,const RsIden
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if(rsReputations->overallReputationLevel(item->signature.keyId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( rsReputations->overallReputationLevel(item->signature.keyId) ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
std::cerr << "(WW) received global router message from banned identity " << item->signature.keyId << ". Rejecting the message." << std::endl;
|
std::cerr << "(WW) received global router message from banned identity " << item->signature.keyId << ". Rejecting the message." << std::endl;
|
||||||
return false ;
|
return false ;
|
||||||
|
@ -912,7 +912,8 @@ int RsGenExchange::validateMsg(RsNxsMsg *msg, const uint32_t& grpFlag, const uin
|
|||||||
// now check reputation of the message author. The reputation will need to be at least as high as this value for the msg to validate.
|
// now check reputation of the message author. The reputation will need to be at least as high as this value for the msg to validate.
|
||||||
// At validation step, we accept all messages, except the ones signed by locally rejected identities.
|
// At validation step, we accept all messages, except the ones signed by locally rejected identities.
|
||||||
|
|
||||||
if(details.mReputation.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( details.mReputation.mOverallReputationLevel ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
#ifdef GEN_EXCH_DEBUG
|
#ifdef GEN_EXCH_DEBUG
|
||||||
std::cerr << "RsGenExchange::validateMsg(): message from " << metaData.mAuthorId << ", rejected because reputation level (" << details.mReputation.mOverallReputationLevel <<") indicate that you banned this ID." << std::endl;
|
std::cerr << "RsGenExchange::validateMsg(): message from " << metaData.mAuthorId << ", rejected because reputation level (" << details.mReputation.mOverallReputationLevel <<") indicate that you banned this ID." << std::endl;
|
||||||
@ -1848,7 +1849,8 @@ uint32_t RsGenExchange::getDefaultSyncPeriod()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RsReputations::ReputationLevel RsGenExchange::minReputationForForwardingMessages(uint32_t group_sign_flags,uint32_t identity_sign_flags)
|
RsReputationLevel RsGenExchange::minReputationForForwardingMessages(
|
||||||
|
uint32_t group_sign_flags, uint32_t identity_sign_flags )
|
||||||
{
|
{
|
||||||
return RsNetworkExchangeService::minReputationForForwardingMessages(group_sign_flags,identity_sign_flags);
|
return RsNetworkExchangeService::minReputationForForwardingMessages(group_sign_flags,identity_sign_flags);
|
||||||
}
|
}
|
||||||
|
@ -712,7 +712,8 @@ public:
|
|||||||
uint16_t serviceType() const { return mServType ; }
|
uint16_t serviceType() const { return mServType ; }
|
||||||
uint32_t serviceFullType() const { return RsServiceInfo::RsServiceInfoUIn16ToFullServiceId(mServType); }
|
uint32_t serviceFullType() const { return RsServiceInfo::RsServiceInfoUIn16ToFullServiceId(mServType); }
|
||||||
|
|
||||||
virtual RsReputations::ReputationLevel minReputationForForwardingMessages(uint32_t group_sign_flags,uint32_t identity_flags);
|
virtual RsReputationLevel minReputationForForwardingMessages(
|
||||||
|
uint32_t group_sign_flags, uint32_t identity_flags );
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
/** Notifications **/
|
/** Notifications **/
|
||||||
|
@ -178,25 +178,23 @@ public:
|
|||||||
uint32_t reputation_level ;
|
uint32_t reputation_level ;
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGixsReputation
|
struct RsGixsReputation
|
||||||
{
|
{
|
||||||
public:
|
virtual RsReputationLevel overallReputationLevel(
|
||||||
// get Reputation.
|
const RsGxsId& id, uint32_t* identity_flags = nullptr ) = 0;
|
||||||
virtual RsReputations::ReputationLevel overallReputationLevel(const RsGxsId& id,uint32_t *identity_flags=NULL) = 0;
|
|
||||||
virtual ~RsGixsReputation(){}
|
virtual ~RsGixsReputation(){}
|
||||||
};
|
};
|
||||||
|
|
||||||
/*** This Class pulls all the GXS Interfaces together ****/
|
/*** This Class pulls all the GXS Interfaces together ****/
|
||||||
|
|
||||||
class RsGxsIdExchange:
|
struct RsGxsIdExchange : RsGenExchange, RsGixs
|
||||||
public RsGenExchange,
|
|
||||||
public RsGixs
|
|
||||||
{
|
{
|
||||||
public:
|
RsGxsIdExchange(
|
||||||
RsGxsIdExchange(RsGeneralDataService* gds, RsNetworkExchangeService* ns, RsSerialType* serviceSerialiser, uint16_t mServType, uint32_t authenPolicy)
|
RsGeneralDataService* gds, RsNetworkExchangeService* ns,
|
||||||
:RsGenExchange(gds,ns,serviceSerialiser,mServType, this, authenPolicy) { return; }
|
RsSerialType* serviceSerialiser, uint16_t mServType,
|
||||||
virtual ~RsGxsIdExchange() { return; }
|
uint32_t authenPolicy )
|
||||||
|
: RsGenExchange(
|
||||||
|
gds, ns, serviceSerialiser, mServType, this, authenPolicy ) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -3034,7 +3034,8 @@ void RsGxsNetService::locked_genReqMsgTransaction(NxsTransaction* tr)
|
|||||||
// - if author is locally banned, do not download.
|
// - if author is locally banned, do not download.
|
||||||
// - if author is not locally banned, download, whatever friends' opinion might be.
|
// - if author is not locally banned, download, whatever friends' opinion might be.
|
||||||
|
|
||||||
if(mReputations->overallReputationLevel(syncItem->authorId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( mReputations->overallReputationLevel(syncItem->authorId) ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
#ifdef NXS_NET_DEBUG_1
|
#ifdef NXS_NET_DEBUG_1
|
||||||
GXSNETDEBUG_PG(item->PeerId(),grpId) << ", Identity " << syncItem->authorId << " is banned. Not requesting message!" << std::endl;
|
GXSNETDEBUG_PG(item->PeerId(),grpId) << ", Identity " << syncItem->authorId << " is banned. Not requesting message!" << std::endl;
|
||||||
@ -3239,7 +3240,9 @@ void RsGxsNetService::locked_genReqGrpTransaction(NxsTransaction* tr)
|
|||||||
// FIXTESTS global variable rsReputations not available in unittests!
|
// FIXTESTS global variable rsReputations not available in unittests!
|
||||||
|
|
||||||
#warning csoler 2016-12-23: Update the code below to correctly send/recv dependign on reputation
|
#warning csoler 2016-12-23: Update the code below to correctly send/recv dependign on reputation
|
||||||
if(!grpSyncItem->authorId.isNull() && mReputations->overallReputationLevel(grpSyncItem->authorId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( !grpSyncItem->authorId.isNull() &&
|
||||||
|
mReputations->overallReputationLevel(grpSyncItem->authorId) ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
#ifdef NXS_NET_DEBUG_0
|
#ifdef NXS_NET_DEBUG_0
|
||||||
GXSNETDEBUG_PG(tr->mTransaction->PeerId(),grpId) << " Identity " << grpSyncItem->authorId << " is banned. Not syncing group." << std::endl;
|
GXSNETDEBUG_PG(tr->mTransaction->PeerId(),grpId) << " Identity " << grpSyncItem->authorId << " is banned. Not syncing group." << std::endl;
|
||||||
|
@ -40,7 +40,8 @@ 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*/)
|
||||||
{
|
{
|
||||||
rep.id = authorId ;
|
rep.id = authorId ;
|
||||||
rep.reputation_level = mRep->overallReputationLevel(authorId);
|
rep.reputation_level =
|
||||||
|
static_cast<uint32_t>(mRep->overallReputationLevel(authorId));
|
||||||
|
|
||||||
#warning csoler 2017-01-10: Can it happen that reputations do not have the info yet?
|
#warning csoler 2017-01-10: Can it happen that reputations do not have the info yet?
|
||||||
return true ;
|
return true ;
|
||||||
|
@ -204,7 +204,10 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
#ifdef DEBUG_GXSUTIL
|
#ifdef DEBUG_GXSUTIL
|
||||||
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( rsReputations && rsReputations->overallReputationLevel(grp->metaData->mAuthorId ) > RsReputations::REPUTATION_LOCALLY_NEGATIVE )
|
if( rsReputations &&
|
||||||
|
rsReputations->overallReputationLevel(
|
||||||
|
grp->metaData->mAuthorId ) >
|
||||||
|
RsReputationLevel::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)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -388,7 +391,10 @@ 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(rsReputations!=NULL && rsReputations->overallReputationLevel(msg->metaData->mAuthorId) > RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( rsReputations &&
|
||||||
|
rsReputations->overallReputationLevel(
|
||||||
|
msg->metaData->mAuthorId ) >
|
||||||
|
RsReputationLevel::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))) ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -253,13 +253,14 @@ public:
|
|||||||
* \param identity_flags Flags of the identity
|
* \param identity_flags Flags of the identity
|
||||||
* \return
|
* \return
|
||||||
*/
|
*/
|
||||||
static RsReputations::ReputationLevel minReputationForRequestingMessages(uint32_t /* group_sign_flags */, uint32_t /* identity_flags */)
|
static RsReputationLevel minReputationForRequestingMessages(
|
||||||
|
uint32_t /* group_sign_flags */, uint32_t /* identity_flags */ )
|
||||||
{
|
{
|
||||||
// We always request messages, except if the author identity is locally banned.
|
// We always request messages, except if the author identity is locally banned.
|
||||||
|
return RsReputationLevel::REMOTELY_NEGATIVE;
|
||||||
return RsReputations::REPUTATION_REMOTELY_NEGATIVE;
|
|
||||||
}
|
}
|
||||||
static RsReputations::ReputationLevel minReputationForForwardingMessages(uint32_t group_sign_flags, uint32_t identity_flags)
|
static RsReputationLevel minReputationForForwardingMessages(
|
||||||
|
uint32_t group_sign_flags, uint32_t identity_flags )
|
||||||
{
|
{
|
||||||
// If anti-spam is enabled, do not send messages from authors with bad reputation. The policy is to only forward messages if the reputation of the author is at least
|
// If anti-spam is enabled, do not send messages from authors with bad reputation. The policy is to only forward messages if the reputation of the author is at least
|
||||||
// equal to the minimal reputation in the table below (R=remotely, L=locally, P=positive, N=negative, O=neutral) :
|
// equal to the minimal reputation in the table below (R=remotely, L=locally, P=positive, N=negative, O=neutral) :
|
||||||
@ -277,20 +278,20 @@ public:
|
|||||||
//
|
//
|
||||||
|
|
||||||
if(identity_flags & RS_IDENTITY_FLAGS_PGP_KNOWN)
|
if(identity_flags & RS_IDENTITY_FLAGS_PGP_KNOWN)
|
||||||
return RsReputations::REPUTATION_NEUTRAL;
|
return RsReputationLevel::NEUTRAL;
|
||||||
else if(identity_flags & RS_IDENTITY_FLAGS_PGP_LINKED)
|
else if(identity_flags & RS_IDENTITY_FLAGS_PGP_LINKED)
|
||||||
{
|
{
|
||||||
if(group_sign_flags & GXS_SERV::FLAG_AUTHOR_AUTHENTICATION_GPG_KNOWN)
|
if(group_sign_flags & GXS_SERV::FLAG_AUTHOR_AUTHENTICATION_GPG_KNOWN)
|
||||||
return RsReputations::REPUTATION_REMOTELY_POSITIVE;
|
return RsReputationLevel::REMOTELY_POSITIVE;
|
||||||
else
|
else
|
||||||
return RsReputations::REPUTATION_NEUTRAL;
|
return RsReputationLevel::NEUTRAL;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if( (group_sign_flags & GXS_SERV::FLAG_AUTHOR_AUTHENTICATION_GPG_KNOWN) || (group_sign_flags & GXS_SERV::FLAG_AUTHOR_AUTHENTICATION_GPG))
|
if( (group_sign_flags & GXS_SERV::FLAG_AUTHOR_AUTHENTICATION_GPG_KNOWN) || (group_sign_flags & GXS_SERV::FLAG_AUTHOR_AUTHENTICATION_GPG))
|
||||||
return RsReputations::REPUTATION_REMOTELY_POSITIVE;
|
return RsReputationLevel::REMOTELY_POSITIVE;
|
||||||
else
|
else
|
||||||
return RsReputations::REPUTATION_NEUTRAL;
|
return RsReputationLevel::NEUTRAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -1256,31 +1256,38 @@ bool p3GxsTrans::acceptNewMessage(const RsGxsMsgMetaData *msgMeta,uint32_t msg_s
|
|||||||
uint32_t max_size = 0 ;
|
uint32_t max_size = 0 ;
|
||||||
uint32_t identity_flags = 0 ;
|
uint32_t identity_flags = 0 ;
|
||||||
|
|
||||||
RsReputations::ReputationLevel rep_lev = rsReputations->overallReputationLevel(msgMeta->mAuthorId,&identity_flags);
|
RsReputationLevel rep_lev =
|
||||||
|
rsReputations->overallReputationLevel(
|
||||||
|
msgMeta->mAuthorId, &identity_flags );
|
||||||
|
|
||||||
switch(rep_lev)
|
switch(rep_lev)
|
||||||
{
|
{
|
||||||
case RsReputations::REPUTATION_REMOTELY_NEGATIVE: max_count = GXSTRANS_MAX_COUNT_REMOTELY_NEGATIVE_DEFAULT;
|
case RsReputationLevel::REMOTELY_NEGATIVE:
|
||||||
max_size = GXSTRANS_MAX_SIZE_REMOTELY_NEGATIVE_DEFAULT;
|
max_count = GXSTRANS_MAX_COUNT_REMOTELY_NEGATIVE_DEFAULT;
|
||||||
break ;
|
max_size = GXSTRANS_MAX_SIZE_REMOTELY_NEGATIVE_DEFAULT;
|
||||||
case RsReputations::REPUTATION_NEUTRAL: max_count = GXSTRANS_MAX_COUNT_NEUTRAL_DEFAULT;
|
|
||||||
max_size = GXSTRANS_MAX_SIZE_NEUTRAL_DEFAULT;
|
|
||||||
break ;
|
|
||||||
case RsReputations::REPUTATION_REMOTELY_POSITIVE: max_count = GXSTRANS_MAX_COUNT_REMOTELY_POSITIVE_DEFAULT;
|
|
||||||
max_size = GXSTRANS_MAX_SIZE_REMOTELY_POSITIVE_DEFAULT;
|
|
||||||
break ;
|
|
||||||
case RsReputations::REPUTATION_LOCALLY_POSITIVE: max_count = GXSTRANS_MAX_COUNT_LOCALLY_POSITIVE_DEFAULT;
|
|
||||||
max_size = GXSTRANS_MAX_SIZE_LOCALLY_POSITIVE_DEFAULT;
|
|
||||||
break ;
|
|
||||||
default:
|
|
||||||
case RsReputations::REPUTATION_LOCALLY_NEGATIVE: max_count = 0 ;
|
|
||||||
max_size = 0 ;
|
|
||||||
break ;
|
break ;
|
||||||
|
case RsReputationLevel::NEUTRAL:
|
||||||
|
max_count = GXSTRANS_MAX_COUNT_NEUTRAL_DEFAULT;
|
||||||
|
max_size = GXSTRANS_MAX_SIZE_NEUTRAL_DEFAULT;
|
||||||
|
break;
|
||||||
|
case RsReputationLevel::REMOTELY_POSITIVE:
|
||||||
|
max_count = GXSTRANS_MAX_COUNT_REMOTELY_POSITIVE_DEFAULT;
|
||||||
|
max_size = GXSTRANS_MAX_SIZE_REMOTELY_POSITIVE_DEFAULT;
|
||||||
|
break;
|
||||||
|
case RsReputationLevel::LOCALLY_POSITIVE:
|
||||||
|
max_count = GXSTRANS_MAX_COUNT_LOCALLY_POSITIVE_DEFAULT;
|
||||||
|
max_size = GXSTRANS_MAX_SIZE_LOCALLY_POSITIVE_DEFAULT;
|
||||||
|
break;
|
||||||
|
case RsReputationLevel::LOCALLY_NEGATIVE: // fallthrough
|
||||||
|
default:
|
||||||
|
max_count = 0;
|
||||||
|
max_size = 0;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool pgp_linked = identity_flags & RS_IDENTITY_FLAGS_PGP_LINKED ;
|
bool pgp_linked = identity_flags & RS_IDENTITY_FLAGS_PGP_LINKED;
|
||||||
|
|
||||||
if(rep_lev <= RsReputations::REPUTATION_NEUTRAL && !pgp_linked)
|
if(rep_lev <= RsReputationLevel::NEUTRAL && !pgp_linked)
|
||||||
{
|
{
|
||||||
max_count /= 10 ;
|
max_count /= 10 ;
|
||||||
max_size /= 10 ;
|
max_size /= 10 ;
|
||||||
@ -1288,7 +1295,7 @@ bool p3GxsTrans::acceptNewMessage(const RsGxsMsgMetaData *msgMeta,uint32_t msg_s
|
|||||||
|
|
||||||
RS_STACK_MUTEX(mPerUserStatsMutex);
|
RS_STACK_MUTEX(mPerUserStatsMutex);
|
||||||
|
|
||||||
MsgSizeCount& s(per_user_statistics[msgMeta->mAuthorId]) ;
|
MsgSizeCount& s(per_user_statistics[msgMeta->mAuthorId]);
|
||||||
|
|
||||||
#ifdef DEBUG_GXSTRANS
|
#ifdef DEBUG_GXSTRANS
|
||||||
std::cerr << "GxsTrans::acceptMessage(): size=" << msg_size << ", grp=" << msgMeta->mGroupId << ", gxs_id=" << msgMeta->mAuthorId << ", pgp_linked=" << pgp_linked << ", current (size,cnt)=("
|
std::cerr << "GxsTrans::acceptMessage(): size=" << msg_size << ", grp=" << msgMeta->mGroupId << ", gxs_id=" << msgMeta->mAuthorId << ", pgp_linked=" << pgp_linked << ", current (size,cnt)=("
|
||||||
|
@ -754,6 +754,7 @@ SOURCES += serialiser/rsserializable.cc \
|
|||||||
|
|
||||||
# Identity Service
|
# Identity Service
|
||||||
HEADERS += retroshare/rsidentity.h \
|
HEADERS += retroshare/rsidentity.h \
|
||||||
|
retroshare/rsreputations.h \
|
||||||
gxs/rsgixs.h \
|
gxs/rsgixs.h \
|
||||||
services/p3idservice.h \
|
services/p3idservice.h \
|
||||||
rsitems/rsgxsiditems.h \
|
rsitems/rsgxsiditems.h \
|
||||||
|
@ -42,7 +42,7 @@ class RsGxsChannels;
|
|||||||
*/
|
*/
|
||||||
extern RsGxsChannels* rsGxsChannels;
|
extern RsGxsChannels* rsGxsChannels;
|
||||||
|
|
||||||
// These should be in rsgxscommon.h
|
|
||||||
struct RsGxsChannelGroup : RsSerializable
|
struct RsGxsChannelGroup : RsSerializable
|
||||||
{
|
{
|
||||||
RsGroupMetaData mMeta;
|
RsGroupMetaData mMeta;
|
||||||
|
@ -3,7 +3,8 @@
|
|||||||
* *
|
* *
|
||||||
* libretroshare: retroshare core library *
|
* libretroshare: retroshare core library *
|
||||||
* *
|
* *
|
||||||
* Copyright 2012-2012 by Robert Fernie <retroshare@lunamutt.com> *
|
* Copyright (C) 2012 Robert Fernie <retroshare@lunamutt.com> *
|
||||||
|
* Copyright (C) 2018 Gioacchino Mazzurco <gio@eigenlab.org> *
|
||||||
* *
|
* *
|
||||||
* This program is free software: you can redistribute it and/or modify *
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
* it under the terms of the GNU Lesser General Public License as *
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
@ -19,34 +20,31 @@
|
|||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
||||||
* *
|
* *
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
#ifndef RETROSHARE_GXSCIRCLES_INTERFACE_H
|
#pragma once
|
||||||
#define RETROSHARE_GXSCIRCLES_INTERFACE_H
|
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <cstdint>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <list>
|
#include <list>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
|
||||||
#include "retroshare/rstypes.h"
|
#include "retroshare/rstypes.h"
|
||||||
|
|
||||||
//typedef std::string RsGxsCircleId;
|
|
||||||
//typedef RsPgpId RsPgpId;
|
|
||||||
//typedef std::string RsCircleInternalId;
|
|
||||||
|
|
||||||
#include "retroshare/rstokenservice.h"
|
#include "retroshare/rstokenservice.h"
|
||||||
#include "retroshare/rsgxsifacehelper.h"
|
#include "retroshare/rsgxsifacehelper.h"
|
||||||
|
|
||||||
#include "retroshare/rsidentity.h"
|
#include "retroshare/rsidentity.h"
|
||||||
|
#include "serialiser/rsserializable.h"
|
||||||
|
|
||||||
|
|
||||||
/* The Main Interface Class - for information about your Peers */
|
|
||||||
class RsGxsCircles;
|
class RsGxsCircles;
|
||||||
extern RsGxsCircles *rsGxsCircles;
|
|
||||||
|
|
||||||
typedef RsPgpId RsPgpId;
|
/**
|
||||||
|
* Pointer to global instance of RsGxsCircles service implementation
|
||||||
|
* @jsonapi{development}
|
||||||
|
*/
|
||||||
|
extern RsGxsCircles* rsGxsCircles;
|
||||||
|
|
||||||
|
|
||||||
|
// TODO: convert to enum
|
||||||
/// The meaning of the different circle types is:
|
/// The meaning of the different circle types is:
|
||||||
/// TODO: convert to enum
|
|
||||||
static const uint32_t GXS_CIRCLE_TYPE_UNKNOWN = 0x0000 ; /// Used to detect uninizialized values.
|
static const uint32_t GXS_CIRCLE_TYPE_UNKNOWN = 0x0000 ; /// Used to detect uninizialized values.
|
||||||
static const uint32_t GXS_CIRCLE_TYPE_PUBLIC = 0x0001 ; // not restricted to a circle
|
static const uint32_t GXS_CIRCLE_TYPE_PUBLIC = 0x0001 ; // not restricted to a circle
|
||||||
static const uint32_t GXS_CIRCLE_TYPE_EXTERNAL = 0x0002 ; // restricted to an external circle, made of RsGxsId
|
static const uint32_t GXS_CIRCLE_TYPE_EXTERNAL = 0x0002 ; // restricted to an external circle, made of RsGxsId
|
||||||
@ -62,90 +60,207 @@ static const uint32_t GXS_EXTERNAL_CIRCLE_FLAGS_ALLOWED = 0x0007 ;// user
|
|||||||
|
|
||||||
static const uint32_t GXS_CIRCLE_FLAGS_IS_EXTERNAL = 0x0008 ;// user is allowed
|
static const uint32_t GXS_CIRCLE_FLAGS_IS_EXTERNAL = 0x0008 ;// user is allowed
|
||||||
|
|
||||||
/* Permissions is part of GroupMetaData */
|
|
||||||
|
|
||||||
class GxsPermissions
|
struct RsGxsCircleGroup : RsSerializable
|
||||||
{
|
{
|
||||||
public:
|
virtual ~RsGxsCircleGroup() {}
|
||||||
uint32_t mCircleType; // PUBLIC, EXTERNAL or YOUREYESONLY.
|
|
||||||
RsGxsCircleId mCircleId; // If EXTERNAL, otherwise Blank.
|
|
||||||
|
|
||||||
// BELOW IS NOT SERIALISED - BUT MUST BE STORED LOCALLY BY GXS. (If YOUREYESONLY)
|
RsGroupMetaData mMeta;
|
||||||
RsPeerId mOriginator;
|
|
||||||
RsGxsCircleId mInternalCircle; // if Originator == ownId, otherwise blank.
|
std::set<RsPgpId> mLocalFriends;
|
||||||
|
std::set<RsGxsId> mInvitedMembers;
|
||||||
|
std::set<RsGxsCircleId> mSubCircles;
|
||||||
|
#ifdef V07_NON_BACKWARD_COMPATIBLE_CHANGE_UNNAMED
|
||||||
|
# error "Add description, and multiple owners/administrators to circles"
|
||||||
|
// or better in general to GXS groups
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/// @see RsSerializable
|
||||||
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
||||||
|
RsGenericSerializer::SerializeContext& ctx) override
|
||||||
|
{
|
||||||
|
RS_SERIAL_PROCESS(mMeta);
|
||||||
|
RS_SERIAL_PROCESS(mLocalFriends);
|
||||||
|
RS_SERIAL_PROCESS(mInvitedMembers);
|
||||||
|
RS_SERIAL_PROCESS(mSubCircles);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGxsCircleGroup
|
struct RsGxsCircleMsg : RsSerializable
|
||||||
{
|
{
|
||||||
public:
|
virtual ~RsGxsCircleMsg() {}
|
||||||
RsGroupMetaData mMeta; // includes GxsPermissions, for control of group distribution.
|
|
||||||
|
|
||||||
std::set<RsPgpId> mLocalFriends;
|
|
||||||
std::set<RsGxsId> mInvitedMembers;
|
|
||||||
std::set<RsGxsCircleId> mSubCircles;
|
|
||||||
|
|
||||||
// Not Serialised.
|
|
||||||
// Internally inside rsCircles, this will be turned into:
|
|
||||||
// std::list<RsPeerId> mAllowedFriends;
|
|
||||||
};
|
|
||||||
|
|
||||||
class RsGxsCircleMsg
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
RsMsgMetaData mMeta;
|
RsMsgMetaData mMeta;
|
||||||
|
|
||||||
// Signature by user signifying that they want to be part of the group.
|
#ifndef V07_NON_BACKWARD_COMPATIBLE_CHANGE_UNNAMED
|
||||||
// maybe Phase 3.
|
/* This is horrible and should be changed into yet to be defined something
|
||||||
|
* reasonable in next non retrocompatible version */
|
||||||
std::string stuff;
|
std::string stuff;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/// @see RsSerializable
|
||||||
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
||||||
|
RsGenericSerializer::SerializeContext& ctx) override
|
||||||
|
{
|
||||||
|
RS_SERIAL_PROCESS(mMeta);
|
||||||
|
RS_SERIAL_PROCESS(stuff);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGxsCircleDetails
|
struct RsGxsCircleDetails : RsSerializable
|
||||||
{
|
{
|
||||||
public:
|
RsGxsCircleDetails() :
|
||||||
RsGxsCircleDetails() : mCircleType(GXS_CIRCLE_TYPE_EXTERNAL), mAmIAllowed(false) {}
|
mCircleType(GXS_CIRCLE_TYPE_EXTERNAL), mAmIAllowed(false) {}
|
||||||
|
~RsGxsCircleDetails() {}
|
||||||
RsGxsCircleId mCircleId;
|
|
||||||
std::string mCircleName;
|
|
||||||
|
|
||||||
uint32_t mCircleType;
|
RsGxsCircleId mCircleId;
|
||||||
RsGxsCircleId mRestrictedCircleId;
|
std::string mCircleName;
|
||||||
|
|
||||||
bool mAmIAllowed ; // true when one of load GXS ids belong to the circle allowed list (admin list & subscribed list).
|
|
||||||
|
|
||||||
std::set<RsGxsId> mAllowedGxsIds; // This crosses admin list and subscribed list
|
uint32_t mCircleType;
|
||||||
std::set<RsPgpId> mAllowedNodes;
|
RsGxsCircleId mRestrictedCircleId;
|
||||||
|
|
||||||
std::map<RsGxsId,uint32_t> mSubscriptionFlags ; // subscription flags for all ids
|
/** true when one of load GXS ids belong to the circle allowed list (admin
|
||||||
|
* list & subscribed list). */
|
||||||
|
bool mAmIAllowed;
|
||||||
|
|
||||||
|
/// This crosses admin list and subscribed list
|
||||||
|
std::set<RsGxsId> mAllowedGxsIds;
|
||||||
|
std::set<RsPgpId> mAllowedNodes;
|
||||||
|
|
||||||
|
/// subscription flags for all ids
|
||||||
|
std::map<RsGxsId,uint32_t> mSubscriptionFlags;
|
||||||
|
|
||||||
|
/// @see RsSerializable
|
||||||
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
||||||
|
RsGenericSerializer::SerializeContext& ctx) override
|
||||||
|
{
|
||||||
|
RS_SERIAL_PROCESS(mCircleId);
|
||||||
|
RS_SERIAL_PROCESS(mCircleName);
|
||||||
|
RS_SERIAL_PROCESS(mCircleType);
|
||||||
|
RS_SERIAL_PROCESS(mRestrictedCircleId);
|
||||||
|
RS_SERIAL_PROCESS(mAmIAllowed);
|
||||||
|
RS_SERIAL_PROCESS(mAllowedGxsIds);
|
||||||
|
RS_SERIAL_PROCESS(mAllowedNodes);
|
||||||
|
RS_SERIAL_PROCESS(mSubscriptionFlags);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGxsCircles: public RsGxsIfaceHelper
|
class RsGxsCircles: public RsGxsIfaceHelper
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
RsGxsCircles(RsGxsIface& gxs) :RsGxsIfaceHelper(gxs) {}
|
RsGxsCircles(RsGxsIface& gxs) : RsGxsIfaceHelper(gxs) {}
|
||||||
virtual ~RsGxsCircles() {}
|
virtual ~RsGxsCircles() {}
|
||||||
|
|
||||||
/* External Interface (Cached stuff) */
|
/**
|
||||||
virtual bool getCircleDetails(const RsGxsCircleId &id, RsGxsCircleDetails &details) = 0;
|
* @brief Create new circle
|
||||||
virtual bool getCircleExternalIdList(std::list<RsGxsCircleId> &circleIds) = 0;
|
* @jsonapi{development}
|
||||||
virtual bool getCirclePersonalIdList(std::list<RsGxsCircleId> &circleIds) = 0;
|
* @param[inout] cData input name and flags of the circle, storage for
|
||||||
|
* generated circle data id etc.
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool createCircle(RsGxsCircleGroup& cData) = 0;
|
||||||
|
|
||||||
/* membership management for external circles */
|
/**
|
||||||
|
* @brief Edit own existing circle
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[inout] cData Circle data with modifications, storage for data
|
||||||
|
* updatedad during the operation.
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool editCircle(RsGxsCircleGroup& cData) = 0;
|
||||||
|
|
||||||
virtual bool requestCircleMembership(const RsGxsId& own_gxsid,const RsGxsCircleId& circle_id)=0 ;
|
/**
|
||||||
virtual bool cancelCircleMembership(const RsGxsId& own_gxsid,const RsGxsCircleId& circle_id)=0 ;
|
* @brief Get circle details. Memory cached
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id of the circle
|
||||||
|
* @param[out] details Storage for the circle details
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool getCircleDetails(
|
||||||
|
const RsGxsCircleId& id, RsGxsCircleDetails& details ) = 0;
|
||||||
|
|
||||||
/* standard load */
|
/**
|
||||||
virtual bool getGroupData(const uint32_t &token, std::vector<RsGxsCircleGroup> &groups) = 0;
|
* @brief Get list of known external circles ids. Memory cached
|
||||||
virtual bool getMsgData(const uint32_t &token, std::vector<RsGxsCircleMsg> &msgs) = 0;
|
* @jsonapi{development}
|
||||||
|
* @param[in] circleIds Storage for circles id list
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool getCircleExternalIdList(
|
||||||
|
std::list<RsGxsCircleId>& circleIds ) = 0;
|
||||||
|
|
||||||
/* make new group */
|
/**
|
||||||
|
* @brief Get circles summaries list.
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[out] circles list where to store the circles summaries
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool getCirclesSummaries(std::list<RsGroupMetaData>& circles) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get circles information
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] circlesIds ids of the circles of which to get the informations
|
||||||
|
* @param[out] circlesInfo storage for the circles informations
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool getCirclesInfo(
|
||||||
|
const std::list<RsGxsGroupId>& circlesIds,
|
||||||
|
std::vector<RsGxsCircleGroup>& circlesInfo ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get circle requests
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] circleId id of the circle of which the requests are requested
|
||||||
|
* @param[out] requests storage for the circle requests
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool getCircleRequests( const RsGxsGroupId& circleId,
|
||||||
|
std::vector<RsGxsCircleMsg>& requests ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Invite identities to circle
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] identities ids of the identities to invite
|
||||||
|
* @param[in] circleId Id of the circle you own and want to invite ids in
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool inviteIdsToCircle( const std::set<RsGxsId>& identities,
|
||||||
|
const RsGxsCircleId& circleId ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Request circle membership, or accept circle invitation
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] ownGxsId Id of own identity to introduce to the circle
|
||||||
|
* @param[in] circleId Id of the circle to which ask for inclusion
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool requestCircleMembership(
|
||||||
|
const RsGxsId& ownGxsId, const RsGxsCircleId& circleId ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Leave given circle
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] ownGxsId Own id to remove from the circle
|
||||||
|
* @param[in] circleId Id of the circle to leave
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool cancelCircleMembership(
|
||||||
|
const RsGxsId& ownGxsId, const RsGxsCircleId& circleId ) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED_FOR("getCirclesSummaries getCirclesInfo")
|
||||||
|
virtual bool getGroupData(
|
||||||
|
const uint32_t& token, std::vector<RsGxsCircleGroup>& groups ) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED_FOR(getCirclesRequests)
|
||||||
|
virtual bool getMsgData(
|
||||||
|
const uint32_t& token, std::vector<RsGxsCircleMsg>& msgs ) = 0;
|
||||||
|
|
||||||
|
/// make new group
|
||||||
|
RS_DEPRECATED_FOR(createCircle)
|
||||||
virtual void createGroup(uint32_t& token, RsGxsCircleGroup &group) = 0;
|
virtual void createGroup(uint32_t& token, RsGxsCircleGroup &group) = 0;
|
||||||
|
|
||||||
/* update an existing group */
|
/// update an existing group
|
||||||
|
RS_DEPRECATED_FOR("editCircle, inviteIdsToCircle")
|
||||||
virtual void updateGroup(uint32_t &token, RsGxsCircleGroup &group) = 0;
|
virtual void updateGroup(uint32_t &token, RsGxsCircleGroup &group) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
@ -217,7 +217,8 @@ struct RsGxsIface
|
|||||||
virtual uint32_t getSyncPeriod(const RsGxsGroupId& grpId) = 0;
|
virtual uint32_t getSyncPeriod(const RsGxsGroupId& grpId) = 0;
|
||||||
virtual void setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs) = 0;
|
virtual void setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs) = 0;
|
||||||
|
|
||||||
virtual RsReputations::ReputationLevel minReputationForForwardingMessages(uint32_t group_sign_flags,uint32_t identity_flags)=0;
|
virtual RsReputationLevel minReputationForForwardingMessages(
|
||||||
|
uint32_t group_sign_flags,uint32_t identity_flags ) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -228,7 +228,8 @@ struct RsGxsIfaceHelper
|
|||||||
mGxs.setSyncPeriod(grpId,age_in_secs);
|
mGxs.setSyncPeriod(grpId,age_in_secs);
|
||||||
}
|
}
|
||||||
|
|
||||||
RsReputations::ReputationLevel minReputationForForwardingMessages(uint32_t group_sign_flags,uint32_t identity_flags)
|
RsReputationLevel minReputationForForwardingMessages(
|
||||||
|
uint32_t group_sign_flags, uint32_t identity_flags )
|
||||||
{
|
{
|
||||||
return mGxs.minReputationForForwardingMessages(group_sign_flags,identity_flags);
|
return mGxs.minReputationForForwardingMessages(group_sign_flags,identity_flags);
|
||||||
}
|
}
|
||||||
|
@ -90,7 +90,9 @@ struct RsGroupMetaData : RsSerializable
|
|||||||
rstime_t mLastPost; // Timestamp for last message. Not used yet.
|
rstime_t mLastPost; // Timestamp for last message. Not used yet.
|
||||||
|
|
||||||
uint32_t mGroupStatus;
|
uint32_t mGroupStatus;
|
||||||
std::string mServiceString; // Service Specific Free-Form extra storage.
|
|
||||||
|
/// Service Specific Free-Form local (non-synced) extra storage.
|
||||||
|
std::string mServiceString;
|
||||||
RsPeerId mOriginator;
|
RsPeerId mOriginator;
|
||||||
RsGxsCircleId mInternalCircle;
|
RsGxsCircleId mInternalCircle;
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
* libretroshare: retroshare core library *
|
* libretroshare: retroshare core library *
|
||||||
* *
|
* *
|
||||||
* Copyright (C) 2012 Robert Fernie <retroshare@lunamutt.com> *
|
* Copyright (C) 2012 Robert Fernie <retroshare@lunamutt.com> *
|
||||||
* Copyright (C) 2018 Gioacchino Mazzurco <gio@eigenlab.org> *
|
* Copyright (C) 2019 Gioacchino Mazzurco <gio@eigenlab.org> *
|
||||||
* *
|
* *
|
||||||
* This program is free software: you can redistribute it and/or modify *
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
* it under the terms of the GNU Lesser General Public License as *
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
@ -20,12 +20,12 @@
|
|||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
||||||
* *
|
* *
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
#ifndef RETROSHARE_IDENTITY_GUI_INTERFACE_H
|
#pragma once
|
||||||
#define RETROSHARE_IDENTITY_GUI_INTERFACE_H
|
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <cstdint>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <list>
|
#include <list>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include "retroshare/rstokenservice.h"
|
#include "retroshare/rstokenservice.h"
|
||||||
#include "retroshare/rsgxsifacehelper.h"
|
#include "retroshare/rsgxsifacehelper.h"
|
||||||
@ -37,9 +37,13 @@
|
|||||||
#include "serialiser/rstypeserializer.h"
|
#include "serialiser/rstypeserializer.h"
|
||||||
#include "util/rsdeprecate.h"
|
#include "util/rsdeprecate.h"
|
||||||
|
|
||||||
/* The Main Interface Class - for information about your Peers */
|
|
||||||
struct RsIdentity;
|
struct RsIdentity;
|
||||||
extern RsIdentity *rsIdentity;
|
|
||||||
|
/**
|
||||||
|
* Pointer to global instance of RsIdentity service implementation
|
||||||
|
* @jsonapi{development}
|
||||||
|
*/
|
||||||
|
extern RsIdentity* rsIdentity;
|
||||||
|
|
||||||
|
|
||||||
// GroupFlags: Only one so far:
|
// GroupFlags: Only one so far:
|
||||||
@ -106,7 +110,7 @@ struct RsGxsIdGroup : RsSerializable
|
|||||||
{
|
{
|
||||||
RsGxsIdGroup() :
|
RsGxsIdGroup() :
|
||||||
mLastUsageTS(0), mPgpKnown(false), mIsAContact(false) {}
|
mLastUsageTS(0), mPgpKnown(false), mIsAContact(false) {}
|
||||||
~RsGxsIdGroup() {}
|
virtual ~RsGxsIdGroup() {}
|
||||||
|
|
||||||
RsGroupMetaData mMeta;
|
RsGroupMetaData mMeta;
|
||||||
|
|
||||||
@ -144,18 +148,18 @@ struct RsGxsIdGroup : RsSerializable
|
|||||||
|
|
||||||
/// @see RsSerializable
|
/// @see RsSerializable
|
||||||
void serial_process( RsGenericSerializer::SerializeJob j,
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
||||||
RsGenericSerializer::SerializeContext& ctx );
|
RsGenericSerializer::SerializeContext& ctx ) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
std::ostream &operator<<(std::ostream &out, const RsGxsIdGroup &group);
|
std::ostream &operator<<(std::ostream &out, const RsGxsIdGroup &group);
|
||||||
|
|
||||||
// DATA TYPE FOR EXTERNAL INTERFACE.
|
// DATA TYPE FOR EXTERNAL INTERFACE.
|
||||||
|
|
||||||
class RsRecognTag
|
struct RsRecognTag
|
||||||
{
|
{
|
||||||
public:
|
RsRecognTag(uint16_t tc, uint16_t tt, bool v) :
|
||||||
RsRecognTag(uint16_t tc, uint16_t tt, bool v)
|
tag_class(tc), tag_type(tt), valid(v) {}
|
||||||
:tag_class(tc), tag_type(tt), valid(v) { return; }
|
|
||||||
uint16_t tag_class;
|
uint16_t tag_class;
|
||||||
uint16_t tag_type;
|
uint16_t tag_type;
|
||||||
bool valid;
|
bool valid;
|
||||||
@ -268,11 +272,11 @@ struct RsIdentityUsage : RsSerializable
|
|||||||
std::string mComment;
|
std::string mComment;
|
||||||
|
|
||||||
bool operator<(const RsIdentityUsage& u) const { return mHash < u.mHash; }
|
bool operator<(const RsIdentityUsage& u) const { return mHash < u.mHash; }
|
||||||
RsFileHash mHash ;
|
RsFileHash mHash;
|
||||||
|
|
||||||
/// @see RsSerializable
|
/// @see RsSerializable
|
||||||
void serial_process( RsGenericSerializer::SerializeJob j,
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
||||||
RsGenericSerializer::SerializeContext& ctx )
|
RsGenericSerializer::SerializeContext& ctx ) override
|
||||||
{
|
{
|
||||||
RS_SERIAL_PROCESS(mServiceId);
|
RS_SERIAL_PROCESS(mServiceId);
|
||||||
RS_SERIAL_PROCESS(mUsageCode);
|
RS_SERIAL_PROCESS(mUsageCode);
|
||||||
@ -311,7 +315,7 @@ struct RsIdentityDetails : RsSerializable
|
|||||||
* reputation system is not finished yet, I leave this in place. We should
|
* reputation system is not finished yet, I leave this in place. We should
|
||||||
* decide what to do with it.
|
* decide what to do with it.
|
||||||
*/
|
*/
|
||||||
RsReputations::ReputationInfo mReputation;
|
RsReputationInfo mReputation;
|
||||||
|
|
||||||
RsGxsImage mAvatar;
|
RsGxsImage mAvatar;
|
||||||
|
|
||||||
@ -329,7 +333,7 @@ struct RsIdentityDetails : RsSerializable
|
|||||||
RS_SERIAL_PROCESS(mFlags);
|
RS_SERIAL_PROCESS(mFlags);
|
||||||
RS_SERIAL_PROCESS(mPgpId);
|
RS_SERIAL_PROCESS(mPgpId);
|
||||||
//RS_SERIAL_PROCESS(mReputation);
|
//RS_SERIAL_PROCESS(mReputation);
|
||||||
//RS_SERIAL_PROCESS(mAvatar);
|
RS_SERIAL_PROCESS(mAvatar);
|
||||||
RS_SERIAL_PROCESS(mPublishTS);
|
RS_SERIAL_PROCESS(mPublishTS);
|
||||||
RS_SERIAL_PROCESS(mLastUsageTS);
|
RS_SERIAL_PROCESS(mLastUsageTS);
|
||||||
RS_SERIAL_PROCESS(mUseCases);
|
RS_SERIAL_PROCESS(mUseCases);
|
||||||
@ -338,73 +342,214 @@ struct RsIdentityDetails : RsSerializable
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** The Main Interface Class for GXS people identities */
|
||||||
struct RsIdentity : RsGxsIfaceHelper
|
struct RsIdentity : RsGxsIfaceHelper
|
||||||
{
|
{
|
||||||
explicit RsIdentity(RsGxsIface& gxs): RsGxsIfaceHelper(gxs) {}
|
explicit RsIdentity(RsGxsIface& gxs) : RsGxsIfaceHelper(gxs) {}
|
||||||
virtual ~RsIdentity() {}
|
virtual ~RsIdentity() {}
|
||||||
|
|
||||||
/********************************************************************************************/
|
/**
|
||||||
/********************************************************************************************/
|
* @brief Create a new identity
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[out] id storage for the created identity Id
|
||||||
|
* @param[in] name Name of the identity
|
||||||
|
* @param[in] avatar Image associated to the identity
|
||||||
|
* @param[in] pseudonimous true for unsigned identity, false otherwise
|
||||||
|
* @param[in] pgpPassword password to unlock PGP to sign identity,
|
||||||
|
* not implemented yet
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool createIdentity(
|
||||||
|
RsGxsId& id,
|
||||||
|
const std::string& name, const RsGxsImage& avatar = RsGxsImage(),
|
||||||
|
bool pseudonimous = true, const std::string& pgpPassword = "" ) = 0;
|
||||||
|
|
||||||
// For Other Services....
|
/**
|
||||||
// It should be impossible for them to get a message which we don't have the identity.
|
* @brief Locally delete given identity
|
||||||
// Its a major error if we don't have the identity.
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id of the identity
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool deleteIdentity(RsGxsId& id) = 0;
|
||||||
|
|
||||||
// We cache all identities, and provide alternative (instantaneous)
|
/**
|
||||||
// functions to extract info, rather than the standard Token system.
|
* @brief Update identity data (name, avatar...)
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] identityData updated identiy data
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool updateIdentity(RsGxsIdGroup& identityData) = 0;
|
||||||
|
|
||||||
//virtual bool getNickname(const RsGxsId &id, std::string &nickname) = 0;
|
/**
|
||||||
virtual bool getIdDetails(const RsGxsId &id, RsIdentityDetails &details) = 0;
|
* @brief Get identity details, from the cache
|
||||||
|
* @param[in] id Id of the identity
|
||||||
|
* @param[out] details Storage for the identity details
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool getIdDetails(const RsGxsId& id, RsIdentityDetails& details) = 0;
|
||||||
|
|
||||||
// Fills up list of all own ids. Returns false if ids are not yet loaded.
|
/**
|
||||||
virtual bool getOwnIds(std::list<RsGxsId> &ownIds,bool only_signed_ids = false) = 0;
|
* @brief Get last seen usage time of given identity
|
||||||
virtual bool isOwnId(const RsGxsId& id) = 0;
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id of the identity
|
||||||
|
* @return timestamp of last seen usage
|
||||||
|
*/
|
||||||
|
virtual rstime_t getLastUsageTS(const RsGxsId& id) = 0;
|
||||||
|
|
||||||
//
|
/**
|
||||||
virtual bool submitOpinion(uint32_t& token, const RsGxsId &id,
|
* @brief Get own signed ids
|
||||||
bool absOpinion, int score) = 0;
|
* @jsonapi{development}
|
||||||
virtual bool createIdentity(uint32_t& token, RsIdentityParameters ¶ms) = 0;
|
* @param[out] ids storage for the ids
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool getOwnSignedIds(std::vector<RsGxsId> ids) = 0;
|
||||||
|
|
||||||
virtual bool updateIdentity(uint32_t& token, RsGxsIdGroup &group) = 0;
|
/**
|
||||||
virtual bool deleteIdentity(uint32_t& token, RsGxsIdGroup &group) = 0;
|
* @brief Get own pseudonimous (unsigned) ids
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[out] ids storage for the ids
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool getOwnPseudonimousIds(std::vector<RsGxsId> ids) = 0;
|
||||||
|
|
||||||
virtual void setDeleteBannedNodesThreshold(uint32_t days) =0;
|
/**
|
||||||
virtual uint32_t deleteBannedNodesThreshold() =0;
|
* @brief Check if an id is own
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id to check
|
||||||
|
* @return true if the id is own, false otherwise
|
||||||
|
*/
|
||||||
|
virtual bool isOwnId(const RsGxsId& id) = 0;
|
||||||
|
|
||||||
virtual bool parseRecognTag(const RsGxsId &id, const std::string &nickname,
|
/**
|
||||||
const std::string &tag, RsRecognTagDetails &details) = 0;
|
* @brief Get base64 representation of an identity
|
||||||
virtual bool getRecognTagRequest(const RsGxsId &id, const std::string &comment,
|
* @jsonapi{development}
|
||||||
uint16_t tag_class, uint16_t tag_type, std::string &tag) = 0;
|
* @param[in] id Id of the identity
|
||||||
|
* @param[out] base64String storage for the identity base64
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool identityToBase64( const RsGxsId& id,
|
||||||
|
std::string& base64String ) = 0;
|
||||||
|
|
||||||
virtual bool setAsRegularContact(const RsGxsId& id,bool is_a_contact) = 0 ;
|
/**
|
||||||
virtual bool isARegularContact(const RsGxsId& id) = 0 ;
|
* @brief Import identity from base64 representation
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] base64String base64 representation of the identity to import
|
||||||
|
* @param[out] id storage for the identity id
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool identityFromBase64( const std::string& base64String,
|
||||||
|
RsGxsId& id ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get identities summaries list.
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[out] ids list where to store the identities
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool getIdentitiesSummaries(std::list<RsGroupMetaData>& ids) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get identities information (name, avatar...).
|
||||||
|
* Blocking API.
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] ids ids of the channels of which to get the informations
|
||||||
|
* @param[out] idsInfo storage for the identities informations
|
||||||
|
* @return false if something failed, true otherwhise
|
||||||
|
*/
|
||||||
|
virtual bool getIdentitiesInfo(
|
||||||
|
const std::set<RsGxsId>& ids,
|
||||||
|
std::vector<RsGxsIdGroup>& idsInfo ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Check if an identity is contact
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id of the identity
|
||||||
|
* @return true if it is a conctact, false otherwise
|
||||||
|
*/
|
||||||
|
virtual bool isARegularContact(const RsGxsId& id) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set/unset identity as contact
|
||||||
|
* @param[in] id Id of the identity
|
||||||
|
* @param[in] isContact true to set, false to unset
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool setAsRegularContact(const RsGxsId& id, bool isContact) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Toggle automatic flagging signed by friends identity as contact
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] enabled true to enable, false to disable
|
||||||
|
*/
|
||||||
|
virtual void setAutoAddFriendIdsAsContact(bool enabled) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Check if automatic signed by friend identity contact flagging is
|
||||||
|
* enabled
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @return true if enabled, false otherwise
|
||||||
|
*/
|
||||||
|
virtual bool autoAddFriendIdsAsContact() = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get number of days after which delete a banned identities
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @return number of days
|
||||||
|
*/
|
||||||
|
virtual uint32_t deleteBannedNodesThreshold() = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set number of days after which delete a banned identities
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] days number of days
|
||||||
|
*/
|
||||||
|
virtual void setDeleteBannedNodesThreshold(uint32_t days) = 0;
|
||||||
|
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
|
virtual bool getGroupSerializedData(
|
||||||
|
const uint32_t& token,
|
||||||
|
std::map<RsGxsId,std::string>& serialized_groups ) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
|
virtual bool parseRecognTag(
|
||||||
|
const RsGxsId &id, const std::string& nickname,
|
||||||
|
const std::string& tag, RsRecognTagDetails& details) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
|
virtual bool getRecognTagRequest(
|
||||||
|
const RsGxsId& id, const std::string& comment, uint16_t tag_class,
|
||||||
|
uint16_t tag_type, std::string& tag) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
virtual uint32_t nbRegularContacts() =0;
|
virtual uint32_t nbRegularContacts() =0;
|
||||||
virtual void setAutoAddFriendIdsAsContact(bool b) =0;
|
|
||||||
virtual bool autoAddFriendIdsAsContact() =0;
|
|
||||||
|
|
||||||
|
RS_DEPRECATED_FOR(identityToBase64)
|
||||||
virtual bool serialiseIdentityToMemory( const RsGxsId& id,
|
virtual bool serialiseIdentityToMemory( const RsGxsId& id,
|
||||||
std::string& radix_string ) = 0;
|
std::string& radix_string ) = 0;
|
||||||
|
RS_DEPRECATED_FOR(identityFromBase64)
|
||||||
virtual bool deserialiseIdentityFromMemory( const std::string& radix_string,
|
virtual bool deserialiseIdentityFromMemory( const std::string& radix_string,
|
||||||
RsGxsId* id = nullptr ) = 0;
|
RsGxsId* id = nullptr ) = 0;
|
||||||
|
|
||||||
/*!
|
/// Fills up list of all own ids. Returns false if ids are not yet loaded.
|
||||||
* \brief overallReputationLevel
|
RS_DEPRECATED_FOR("getOwnSignedIds getOwnPseudonimousIds")
|
||||||
* Returns the overall reputation level of the supplied identity. See rsreputations.h
|
virtual bool getOwnIds( std::list<RsGxsId> &ownIds,
|
||||||
* \param id
|
bool only_signed_ids = false ) = 0;
|
||||||
* \return
|
|
||||||
*/
|
|
||||||
virtual rstime_t getLastUsageTS(const RsGxsId &id) =0;
|
|
||||||
|
|
||||||
// Specific RsIdentity Functions....
|
RS_DEPRECATED
|
||||||
/* Specific Service Data */
|
virtual bool createIdentity(uint32_t& token, RsIdentityParameters ¶ms) = 0;
|
||||||
/* We expose these initially for testing / GUI purposes.
|
|
||||||
*/
|
|
||||||
|
|
||||||
virtual bool getGroupData(const uint32_t &token, std::vector<RsGxsIdGroup> &groups) = 0;
|
RS_DEPRECATED_FOR(RsReputations)
|
||||||
virtual bool getGroupSerializedData(const uint32_t &token, std::map<RsGxsId,std::string>& serialized_groups)=0;
|
virtual bool submitOpinion(uint32_t& token, const RsGxsId &id,
|
||||||
//virtual bool getMsgData(const uint32_t &token, std::vector<RsGxsIdOpinion> &opinions) = 0;
|
bool absOpinion, int score) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
|
virtual bool updateIdentity(uint32_t& token, RsGxsIdGroup &group) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
|
virtual bool deleteIdentity(uint32_t& token, RsGxsIdGroup &group) = 0;
|
||||||
|
|
||||||
|
RS_DEPRECATED_FOR("getIdentitiesSummaries getIdentitiesInfo")
|
||||||
|
virtual bool getGroupData( const uint32_t& token,
|
||||||
|
std::vector<RsGxsIdGroup>& groups) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // RETROSHARE_IDENTITY_GUI_INTERFACE_H
|
|
||||||
|
@ -3,7 +3,8 @@
|
|||||||
* *
|
* *
|
||||||
* libretroshare: retroshare core library *
|
* libretroshare: retroshare core library *
|
||||||
* *
|
* *
|
||||||
* Copyright 2015 by Cyril Soler <retroshare.team@gmail.com> *
|
* Copyright (C) 2015 Cyril Soler <retroshare.team@gmail.com> *
|
||||||
|
* Copyright (C) 2018 Gioacchino Mazzurco <gio@altermundi.net> *
|
||||||
* *
|
* *
|
||||||
* This program is free software: you can redistribute it and/or modify *
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
* it under the terms of the GNU Lesser General Public License as *
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
@ -19,74 +20,225 @@
|
|||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
||||||
* *
|
* *
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "retroshare/rsids.h"
|
#include "retroshare/rsids.h"
|
||||||
#include "retroshare/rsgxsifacetypes.h"
|
#include "retroshare/rsgxsifacetypes.h"
|
||||||
|
#include "serialiser/rsserializable.h"
|
||||||
|
|
||||||
|
class RsReputations;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pointer to global instance of RsReputations service implementation
|
||||||
|
* @jsonapi{development}
|
||||||
|
*/
|
||||||
|
extern RsReputations* rsReputations;
|
||||||
|
|
||||||
|
|
||||||
|
constexpr float RS_REPUTATION_THRESHOLD_DEFAULT = 1.0f;
|
||||||
|
|
||||||
|
enum struct RsOpinion : uint8_t
|
||||||
|
{
|
||||||
|
NEGATIVE = 0,
|
||||||
|
NEUTRAL = 1,
|
||||||
|
POSITIVE = 2
|
||||||
|
};
|
||||||
|
|
||||||
|
enum struct RsReputationLevel : uint8_t
|
||||||
|
{
|
||||||
|
/// local opinion is negative
|
||||||
|
LOCALLY_NEGATIVE = 0x00,
|
||||||
|
|
||||||
|
/// local opinion is neutral and friends are positive in average
|
||||||
|
REMOTELY_NEGATIVE = 0x01,
|
||||||
|
|
||||||
|
/// no reputation information
|
||||||
|
NEUTRAL = 0x02,
|
||||||
|
|
||||||
|
/// local opinion is neutral and friends are positive in average
|
||||||
|
REMOTELY_POSITIVE = 0x03,
|
||||||
|
|
||||||
|
/// local opinion is positive
|
||||||
|
LOCALLY_POSITIVE = 0x04,
|
||||||
|
|
||||||
|
/// missing info
|
||||||
|
UNKNOWN = 0x05
|
||||||
|
};
|
||||||
|
|
||||||
|
struct RsReputationInfo : RsSerializable
|
||||||
|
{
|
||||||
|
RsReputationInfo() :
|
||||||
|
mOwnOpinion(RsOpinion::NEUTRAL), mFriendsPositiveVotes(0),
|
||||||
|
mFriendsNegativeVotes(0),
|
||||||
|
mFriendAverageScore(RS_REPUTATION_THRESHOLD_DEFAULT),
|
||||||
|
mOverallReputationLevel(RsReputationLevel::NEUTRAL) {}
|
||||||
|
virtual ~RsReputationInfo() {}
|
||||||
|
|
||||||
|
RsOpinion mOwnOpinion;
|
||||||
|
|
||||||
|
uint32_t mFriendsPositiveVotes;
|
||||||
|
uint32_t mFriendsNegativeVotes;
|
||||||
|
|
||||||
|
float mFriendAverageScore;
|
||||||
|
|
||||||
|
/// this should help clients in taking decisions
|
||||||
|
RsReputationLevel mOverallReputationLevel;
|
||||||
|
|
||||||
|
/// @see RsSerializable
|
||||||
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
||||||
|
RsGenericSerializer::SerializeContext& ctx ) override
|
||||||
|
{
|
||||||
|
RS_SERIAL_PROCESS(mOwnOpinion);
|
||||||
|
RS_SERIAL_PROCESS(mFriendsPositiveVotes);
|
||||||
|
RS_SERIAL_PROCESS(mFriendsNegativeVotes);
|
||||||
|
RS_SERIAL_PROCESS(mFriendAverageScore);
|
||||||
|
RS_SERIAL_PROCESS(mOverallReputationLevel);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
class RsReputations
|
class RsReputations
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
static const float REPUTATION_THRESHOLD_ANTI_SPAM;
|
virtual ~RsReputations() {}
|
||||||
static const float REPUTATION_THRESHOLD_DEFAULT;
|
|
||||||
|
|
||||||
// This is the interface file for the reputation system
|
|
||||||
//
|
|
||||||
enum Opinion { OPINION_NEGATIVE = 0, OPINION_NEUTRAL = 1, OPINION_POSITIVE = 2 } ;
|
|
||||||
|
|
||||||
enum ReputationLevel { REPUTATION_LOCALLY_NEGATIVE = 0x00, // local opinion is positive
|
/**
|
||||||
REPUTATION_REMOTELY_NEGATIVE = 0x01, // local opinion is neutral and friends are positive in average
|
* @brief Set own opinion about the given identity
|
||||||
REPUTATION_NEUTRAL = 0x02, // no reputation information ;
|
* @jsonapi{development}
|
||||||
REPUTATION_REMOTELY_POSITIVE = 0x03, // local opinion is neutral and friends are negative in average
|
* @param[in] id Id of the identity
|
||||||
REPUTATION_LOCALLY_POSITIVE = 0x04, // local opinion is negative
|
* @param[in] op Own opinion
|
||||||
REPUTATION_UNKNOWN = 0x05 // missing info
|
* @return false on error, true otherwise
|
||||||
};
|
*/
|
||||||
|
virtual bool setOwnOpinion(const RsGxsId& id, RsOpinion op) = 0;
|
||||||
|
|
||||||
struct ReputationInfo
|
/**
|
||||||
{
|
* @brief Get own opition about the given identity
|
||||||
ReputationInfo() : mOwnOpinion(OPINION_NEUTRAL),mFriendsPositiveVotes(0),mFriendsNegativeVotes(0), mFriendAverageScore(REPUTATION_THRESHOLD_DEFAULT),mOverallReputationLevel(REPUTATION_NEUTRAL){}
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id of the identity
|
||||||
RsReputations::Opinion mOwnOpinion ;
|
* @param[out] op Own opinion
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool getOwnOpinion(const RsGxsId& id, RsOpinion& op) = 0;
|
||||||
|
|
||||||
uint32_t mFriendsPositiveVotes ;
|
/**
|
||||||
uint32_t mFriendsNegativeVotes ;
|
* @brief Get reputation data of given identity
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id of the identity
|
||||||
|
* @param[in] ownerNode Optiona PGP id of the signed identity, accept a null
|
||||||
|
* (all zero/noninitialized) PGP id
|
||||||
|
* @param[out] info storage for the information
|
||||||
|
* @param[in] stamp if true, timestamo the information
|
||||||
|
* @return false on error, true otherwise
|
||||||
|
*/
|
||||||
|
virtual bool getReputationInfo(
|
||||||
|
const RsGxsId& id, const RsPgpId& ownerNode, RsReputationInfo& info,
|
||||||
|
bool stamp = true ) = 0;
|
||||||
|
|
||||||
float mFriendAverageScore ;
|
/**
|
||||||
|
* @brief Get overall reputation level of given identity
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] id Id of the identity
|
||||||
|
* @return the calculated reputation level based on available information
|
||||||
|
*/
|
||||||
|
virtual RsReputationLevel overallReputationLevel(const RsGxsId& id) = 0;
|
||||||
|
|
||||||
RsReputations::ReputationLevel mOverallReputationLevel; // this should help clients in taking decisions
|
/**
|
||||||
};
|
* @brief Enable giving automatic positive opinion when flagging as contact
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] b true to enable, false to disable
|
||||||
|
*/
|
||||||
|
virtual void setAutoPositiveOpinionForContacts(bool b) = 0;
|
||||||
|
|
||||||
virtual bool setOwnOpinion(const RsGxsId& key_id, const Opinion& op) =0;
|
/**
|
||||||
virtual bool getOwnOpinion(const RsGxsId& key_id, Opinion& op) =0;
|
* @brief check if giving automatic positive opinion when flagging as
|
||||||
virtual bool getReputationInfo(const RsGxsId& id, const RsPgpId &ownerNode, ReputationInfo& info,bool stamp=true) =0;
|
* contact is enbaled
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @return true if enabled, false otherwise
|
||||||
|
*/
|
||||||
|
virtual bool autoPositiveOpinionForContacts() = 0;
|
||||||
|
|
||||||
// This returns the reputation level and also the flags of the identity service for that id. This is useful in order to get these flags without relying on the async method of p3Identity
|
/**
|
||||||
|
* @brief Set threshold on remote reputation to consider it remotely
|
||||||
|
* negative
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] thresh Threshold value
|
||||||
|
*/
|
||||||
|
virtual void setThresholdForRemotelyNegativeReputation(uint32_t thresh) = 0;
|
||||||
|
|
||||||
virtual ReputationLevel overallReputationLevel(const RsGxsId& id,uint32_t *identity_flags=NULL)=0;
|
/**
|
||||||
|
* * @brief Get threshold on remote reputation to consider it remotely
|
||||||
|
* negative
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @return Threshold value
|
||||||
|
*/
|
||||||
|
virtual uint32_t thresholdForRemotelyNegativeReputation() = 0;
|
||||||
|
|
||||||
// parameters
|
/**
|
||||||
|
* @brief Set threshold on remote reputation to consider it remotely
|
||||||
|
* positive
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] thresh Threshold value
|
||||||
|
*/
|
||||||
|
virtual void setThresholdForRemotelyPositiveReputation(uint32_t thresh) = 0;
|
||||||
|
|
||||||
virtual void setNodeAutoPositiveOpinionForContacts(bool b) =0;
|
/**
|
||||||
virtual bool nodeAutoPositiveOpinionForContacts() =0;
|
* @brief Get threshold on remote reputation to consider it remotely
|
||||||
|
* negative
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @return Threshold value
|
||||||
|
*/
|
||||||
|
virtual uint32_t thresholdForRemotelyPositiveReputation() = 0;
|
||||||
|
|
||||||
virtual uint32_t thresholdForRemotelyNegativeReputation()=0;
|
/**
|
||||||
virtual uint32_t thresholdForRemotelyPositiveReputation()=0;
|
* @brief Get number of days to wait before deleting a banned identity from
|
||||||
virtual void setThresholdForRemotelyNegativeReputation(uint32_t thresh)=0;
|
* local storage
|
||||||
virtual void setThresholdForRemotelyPositiveReputation(uint32_t thresh)=0;
|
* @jsonapi{development}
|
||||||
|
* @return number of days to wait, 0 means never delete
|
||||||
|
*/
|
||||||
|
virtual uint32_t rememberBannedIdThreshold() = 0;
|
||||||
|
|
||||||
virtual void setRememberDeletedNodesThreshold(uint32_t days) =0;
|
/**
|
||||||
virtual uint32_t rememberDeletedNodesThreshold() =0;
|
* @brief Set number of days to wait before deleting a banned identity from
|
||||||
|
* local storage
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] days number of days to wait, 0 means never delete
|
||||||
|
*/
|
||||||
|
virtual void setRememberBannedIdThreshold(uint32_t days) = 0;
|
||||||
|
|
||||||
// This one is a proxy designed to allow fast checking of a GXS id.
|
/**
|
||||||
// it basically returns true if assessment is not ASSESSMENT_OK
|
* @brief This method allow fast checking if a GXS identity is banned.
|
||||||
|
* @jsonapi{development}
|
||||||
virtual bool isIdentityBanned(const RsGxsId& id) =0;
|
* @param[in] id Id of the identity to check
|
||||||
|
* @return true if identity is banned, false otherwise
|
||||||
|
*/
|
||||||
|
virtual bool isIdentityBanned(const RsGxsId& id) = 0;
|
||||||
|
|
||||||
virtual bool isNodeBanned(const RsPgpId& id) =0;
|
/**
|
||||||
virtual void banNode(const RsPgpId& id,bool b) =0;
|
* @brief Check if automatic banning of all identities signed by the given
|
||||||
|
* node is enabled
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] id PGP id of the node
|
||||||
|
* @return true if enabled, false otherwise
|
||||||
|
*/
|
||||||
|
virtual bool isNodeBanned(const RsPgpId& id) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Enable automatic banning of all identities signed by the given
|
||||||
|
* node
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @param[in] id PGP id of the node
|
||||||
|
* @param[in] b true to enable, false to disable
|
||||||
|
*/
|
||||||
|
virtual void banNode(const RsPgpId& id, bool b) = 0;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated
|
||||||
|
* This returns the reputation level and also the flags of the identity
|
||||||
|
* service for that id. This is useful in order to get these flags without
|
||||||
|
* relying on the async method of p3Identity
|
||||||
|
*/
|
||||||
|
RS_DEPRECATED
|
||||||
|
virtual RsReputationLevel overallReputationLevel(
|
||||||
|
const RsGxsId& id, uint32_t* identity_flags ) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
// To access reputations from anywhere
|
|
||||||
//
|
|
||||||
extern RsReputations *rsReputations ;
|
|
||||||
|
@ -100,7 +100,7 @@ class RsGxsReputationSetItem: public RsReputationItem
|
|||||||
public:
|
public:
|
||||||
RsGxsReputationSetItem() :RsReputationItem(RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM)
|
RsGxsReputationSetItem() :RsReputationItem(RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM)
|
||||||
{
|
{
|
||||||
mOwnOpinion = RsReputations::OPINION_NEUTRAL ;
|
mOwnOpinion = static_cast<uint32_t>(RsOpinion::NEUTRAL);
|
||||||
mOwnOpinionTS = 0;
|
mOwnOpinionTS = 0;
|
||||||
mIdentityFlags = 0;
|
mIdentityFlags = 0;
|
||||||
mLastUsedTS = 0;
|
mLastUsedTS = 0;
|
||||||
|
@ -153,7 +153,118 @@ RsServiceInfo p3GxsCircles::getServiceInfo()
|
|||||||
GXS_CIRCLES_MIN_MINOR_VERSION);
|
GXS_CIRCLES_MIN_MINOR_VERSION);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool p3GxsCircles::createCircle(RsGxsCircleGroup& cData)
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
createGroup(token, cData);
|
||||||
|
|
||||||
|
if(waitToken(token) != RsTokenService::COMPLETE)
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! GXS operation failed."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!RsGenExchange::getPublishedGroupMeta(token, cData.mMeta))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Failure getting created"
|
||||||
|
<< " group data." << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3GxsCircles::editCircle(RsGxsCircleGroup& cData)
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
updateGroup(token, cData);
|
||||||
|
|
||||||
|
if(waitToken(token) != RsTokenService::COMPLETE)
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! GXS operation failed."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!RsGenExchange::getPublishedGroupMeta(token, cData.mMeta))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Failure getting updated"
|
||||||
|
<< " group data." << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3GxsCircles::getCirclesSummaries(std::list<RsGroupMetaData>& circles)
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
RsTokReqOptions opts;
|
||||||
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_META;
|
||||||
|
if( !requestGroupInfo(token, opts)
|
||||||
|
|| waitToken(token) != RsTokenService::COMPLETE ) return false;
|
||||||
|
return getGroupSummary(token, circles);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3GxsCircles::getCirclesInfo( const std::list<RsGxsGroupId>& circlesIds,
|
||||||
|
std::vector<RsGxsCircleGroup>& circlesInfo )
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
RsTokReqOptions opts;
|
||||||
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_DATA;
|
||||||
|
if( !requestGroupInfo(token, opts, circlesIds)
|
||||||
|
|| waitToken(token) != RsTokenService::COMPLETE ) return false;
|
||||||
|
return getGroupData(token, circlesInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3GxsCircles::getCircleRequests( const RsGxsGroupId& circleId,
|
||||||
|
std::vector<RsGxsCircleMsg>& requests )
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
std::list<RsGxsGroupId> grpIds { circleId };
|
||||||
|
RsTokReqOptions opts;
|
||||||
|
opts.mReqType = GXS_REQUEST_TYPE_MSG_DATA;
|
||||||
|
|
||||||
|
if( !requestMsgInfo(token, opts, grpIds) ||
|
||||||
|
waitToken(token) != RsTokenService::COMPLETE ) return false;
|
||||||
|
|
||||||
|
return getMsgData(token, requests);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3GxsCircles::inviteIdsToCircle( const std::set<RsGxsId>& identities,
|
||||||
|
const RsGxsCircleId& circleId )
|
||||||
|
{
|
||||||
|
const std::list<RsGxsGroupId> circlesIds{ RsGxsGroupId(circleId) };
|
||||||
|
std::vector<RsGxsCircleGroup> circlesInfo;
|
||||||
|
|
||||||
|
if(!getCirclesInfo(circlesIds, circlesInfo))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Failure getting group data."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(circlesInfo.empty())
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Circle: "
|
||||||
|
<< circleId.toStdString() << " not found!" << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RsGxsCircleGroup& circleGrp = circlesInfo[0];
|
||||||
|
|
||||||
|
if(!(circleGrp.mMeta.mSubscribeFlags & GXS_SERV::GROUP_SUBSCRIBE_ADMIN))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Attempt to edit non-own "
|
||||||
|
<< "circle: " << circleId.toStdString() << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
circleGrp.mInvitedMembers.insert(identities.begin(), identities.end());
|
||||||
|
|
||||||
|
return editCircle(circleGrp);
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t p3GxsCircles::circleAuthenPolicy()
|
uint32_t p3GxsCircles::circleAuthenPolicy()
|
||||||
{
|
{
|
||||||
@ -320,32 +431,6 @@ bool p3GxsCircles:: getCircleDetails(const RsGxsCircleId &id, RsGxsCircleDetails
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool p3GxsCircles:: getCirclePersonalIdList(std::list<RsGxsCircleId> &circleIds)
|
|
||||||
{
|
|
||||||
#ifdef DEBUG_CIRCLES
|
|
||||||
std::cerr << "p3GxsCircles::getCircleIdList()";
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif // DEBUG_CIRCLES
|
|
||||||
|
|
||||||
RsStackMutex stack(mCircleMtx); /********** STACK LOCKED MTX ******/
|
|
||||||
if (circleIds.empty())
|
|
||||||
{
|
|
||||||
circleIds = mCirclePersonalIdList;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
std::list<RsGxsCircleId>::const_iterator it;
|
|
||||||
for(it = mCirclePersonalIdList.begin(); it != mCirclePersonalIdList.begin(); ++it)
|
|
||||||
{
|
|
||||||
circleIds.push_back(*it);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool p3GxsCircles:: getCircleExternalIdList(std::list<RsGxsCircleId> &circleIds)
|
bool p3GxsCircles:: getCircleExternalIdList(std::list<RsGxsCircleId> &circleIds)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_CIRCLES
|
#ifdef DEBUG_CIRCLES
|
||||||
|
@ -179,9 +179,30 @@ virtual RsServiceInfo getServiceInfo();
|
|||||||
|
|
||||||
/*********** External Interface ***************/
|
/*********** External Interface ***************/
|
||||||
|
|
||||||
|
/// @see RsGxsCircles
|
||||||
|
bool createCircle(RsGxsCircleGroup& cData) override;
|
||||||
|
|
||||||
|
/// @see RsGxsCircles
|
||||||
|
bool editCircle(RsGxsCircleGroup& cData) override;
|
||||||
|
|
||||||
|
/// @see RsGxsCircles
|
||||||
|
bool getCirclesSummaries(std::list<RsGroupMetaData>& circles) override;
|
||||||
|
|
||||||
|
/// @see RsGxsCircles
|
||||||
|
bool getCirclesInfo(
|
||||||
|
const std::list<RsGxsGroupId>& circlesIds,
|
||||||
|
std::vector<RsGxsCircleGroup>& circlesInfo ) override;
|
||||||
|
|
||||||
|
/// @see RsGxsCircles
|
||||||
|
bool getCircleRequests( const RsGxsGroupId& circleId,
|
||||||
|
std::vector<RsGxsCircleMsg>& requests ) override;
|
||||||
|
|
||||||
|
/// @see RsGxsCircles
|
||||||
|
bool inviteIdsToCircle( const std::set<RsGxsId>& identities,
|
||||||
|
const RsGxsCircleId& circleId ) override;
|
||||||
|
|
||||||
virtual bool getCircleDetails(const RsGxsCircleId &id, RsGxsCircleDetails &details);
|
virtual bool getCircleDetails(const RsGxsCircleId &id, RsGxsCircleDetails &details);
|
||||||
virtual bool getCircleExternalIdList(std::list<RsGxsCircleId> &circleIds);
|
virtual bool getCircleExternalIdList(std::list<RsGxsCircleId> &circleIds);
|
||||||
virtual bool getCirclePersonalIdList(std::list<RsGxsCircleId> &circleIds);
|
|
||||||
|
|
||||||
virtual bool isLoaded(const RsGxsCircleId &circleId);
|
virtual bool isLoaded(const RsGxsCircleId &circleId);
|
||||||
virtual bool loadCircle(const RsGxsCircleId &circleId);
|
virtual bool loadCircle(const RsGxsCircleId &circleId);
|
||||||
@ -257,6 +278,8 @@ virtual RsServiceInfo getServiceInfo();
|
|||||||
// put a circle id into the external or personal circle id list
|
// put a circle id into the external or personal circle id list
|
||||||
// this function locks the mutex
|
// this function locks the mutex
|
||||||
// if the id is already in the list, it will not be added again
|
// if the id is already in the list, it will not be added again
|
||||||
|
// G10h4ck: this is terrible, an std::set instead of a list should be used
|
||||||
|
// to guarantee uniqueness
|
||||||
void addCircleIdToList(const RsGxsCircleId& circleId, uint32_t circleType);
|
void addCircleIdToList(const RsGxsCircleId& circleId, uint32_t circleType);
|
||||||
|
|
||||||
RsMutex mCircleMtx; /* Locked Below Here */
|
RsMutex mCircleMtx; /* Locked Below Here */
|
||||||
|
@ -236,7 +236,7 @@ int p3GxsReputation::tick()
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void p3GxsReputation::setNodeAutoPositiveOpinionForContacts(bool b)
|
void p3GxsReputation::setAutoPositiveOpinionForContacts(bool b)
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
@ -249,13 +249,13 @@ void p3GxsReputation::setNodeAutoPositiveOpinionForContacts(bool b)
|
|||||||
IndicateConfigChanged() ;
|
IndicateConfigChanged() ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
bool p3GxsReputation::nodeAutoPositiveOpinionForContacts()
|
bool p3GxsReputation::autoPositiveOpinionForContacts()
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
||||||
return mAutoSetPositiveOptionToContacts ;
|
return mAutoSetPositiveOptionToContacts ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void p3GxsReputation::setRememberDeletedNodesThreshold(uint32_t days)
|
void p3GxsReputation::setRememberBannedIdThreshold(uint32_t days)
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
@ -265,7 +265,7 @@ void p3GxsReputation::setRememberDeletedNodesThreshold(uint32_t days)
|
|||||||
IndicateConfigChanged();
|
IndicateConfigChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
uint32_t p3GxsReputation::rememberDeletedNodesThreshold()
|
uint32_t p3GxsReputation::rememberBannedIdThreshold()
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
@ -382,7 +382,10 @@ void p3GxsReputation::cleanup()
|
|||||||
{
|
{
|
||||||
bool should_delete = false ;
|
bool should_delete = false ;
|
||||||
|
|
||||||
if(it->second.mOwnOpinion == RsReputations::OPINION_NEGATIVE && mMaxPreventReloadBannedIds != 0 && it->second.mOwnOpinionTs + mMaxPreventReloadBannedIds < now)
|
if( it->second.mOwnOpinion ==
|
||||||
|
static_cast<int32_t>(RsOpinion::NEGATIVE) &&
|
||||||
|
mMaxPreventReloadBannedIds != 0 &&
|
||||||
|
it->second.mOwnOpinionTs + mMaxPreventReloadBannedIds < now )
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_REPUTATION
|
#ifdef DEBUG_REPUTATION
|
||||||
std::cerr << " ID " << it->first << ": own is negative for more than " << mMaxPreventReloadBannedIds/86400 << " days. Reseting it!" << std::endl;
|
std::cerr << " ID " << it->first << ": own is negative for more than " << mMaxPreventReloadBannedIds/86400 << " days. Reseting it!" << std::endl;
|
||||||
@ -392,7 +395,10 @@ void p3GxsReputation::cleanup()
|
|||||||
|
|
||||||
// Delete slots with basically no information
|
// Delete slots with basically no information
|
||||||
|
|
||||||
if(it->second.mOpinions.empty() && it->second.mOwnOpinion == RsReputations::OPINION_NEUTRAL && (it->second.mOwnerNode.isNull()))
|
if( it->second.mOpinions.empty() &&
|
||||||
|
it->second.mOwnOpinion ==
|
||||||
|
static_cast<int32_t>(RsOpinion::NEUTRAL) &&
|
||||||
|
it->second.mOwnerNode.isNull() )
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_REPUTATION
|
#ifdef DEBUG_REPUTATION
|
||||||
std::cerr << " ID " << it->first << ": own is neutral and no opinions from friends => remove entry" << std::endl;
|
std::cerr << " ID " << it->first << ": own is neutral and no opinions from friends => remove entry" << std::endl;
|
||||||
@ -461,23 +467,20 @@ void p3GxsReputation::cleanup()
|
|||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
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)
|
||||||
if(it->second.mOwnOpinion == RsReputations::OPINION_NEUTRAL)
|
if( it->second.mOwnOpinion ==
|
||||||
|
static_cast<int32_t>(RsOpinion::NEUTRAL) )
|
||||||
should_set_to_positive_candidates.push_back(it->first) ;
|
should_set_to_positive_candidates.push_back(it->first) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
for(std::list<RsGxsId>::const_iterator it(should_set_to_positive_candidates.begin());it!=should_set_to_positive_candidates.end();++it)
|
for(std::list<RsGxsId>::const_iterator it(should_set_to_positive_candidates.begin());it!=should_set_to_positive_candidates.end();++it)
|
||||||
if(rsIdentity->isARegularContact(*it))
|
if(rsIdentity->isARegularContact(*it))
|
||||||
setOwnOpinion(*it,RsReputations::OPINION_POSITIVE) ;
|
setOwnOpinion(*it, RsOpinion::POSITIVE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const float RsReputations::REPUTATION_THRESHOLD_ANTI_SPAM = 1.4f ;
|
static RsOpinion safe_convert_uint32t_to_opinion(uint32_t op)
|
||||||
const float RsReputations::REPUTATION_THRESHOLD_DEFAULT = 1.0f ;
|
|
||||||
|
|
||||||
|
|
||||||
static RsReputations::Opinion safe_convert_uint32t_to_opinion(uint32_t op)
|
|
||||||
{
|
{
|
||||||
return RsReputations::Opinion(std::min((uint32_t)op,UPPER_LIMIT)) ;
|
return RsOpinion(std::min( static_cast<uint32_t>(op), UPPER_LIMIT ));
|
||||||
}
|
}
|
||||||
/***** Implementation ******/
|
/***** Implementation ******/
|
||||||
|
|
||||||
@ -631,13 +634,14 @@ bool p3GxsReputation::SendReputations(RsGxsReputationRequestItem *request)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void p3GxsReputation::locked_updateOpinion(const RsPeerId& from,const RsGxsId& about,RsReputations::Opinion op)
|
void p3GxsReputation::locked_updateOpinion(
|
||||||
|
const RsPeerId& from, const RsGxsId& about, RsOpinion op )
|
||||||
{
|
{
|
||||||
/* find matching Reputation */
|
/* find matching Reputation */
|
||||||
std::map<RsGxsId, Reputation>::iterator rit = mReputations.find(about);
|
std::map<RsGxsId, Reputation>::iterator rit = mReputations.find(about);
|
||||||
|
|
||||||
RsReputations::Opinion new_opinion = safe_convert_uint32t_to_opinion(op);
|
RsOpinion new_opinion = op;
|
||||||
RsReputations::Opinion old_opinion = RsReputations::OPINION_NEUTRAL ; // default if not set
|
RsOpinion old_opinion = RsOpinion::NEUTRAL ; // default if not set
|
||||||
|
|
||||||
bool updated = false ;
|
bool updated = false ;
|
||||||
|
|
||||||
@ -658,9 +662,9 @@ void p3GxsReputation::locked_updateOpinion(const RsPeerId& from,const RsGxsId& a
|
|||||||
std::cerr << " no preview record"<< std::endl;
|
std::cerr << " no preview record"<< std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(new_opinion != RsReputations::OPINION_NEUTRAL)
|
if(new_opinion != RsOpinion::NEUTRAL)
|
||||||
{
|
{
|
||||||
mReputations[about] = Reputation(about);
|
mReputations[about] = Reputation();
|
||||||
rit = mReputations.find(about);
|
rit = mReputations.find(about);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -674,11 +678,11 @@ void p3GxsReputation::locked_updateOpinion(const RsPeerId& from,const RsGxsId& a
|
|||||||
|
|
||||||
Reputation& reputation = rit->second;
|
Reputation& reputation = rit->second;
|
||||||
|
|
||||||
std::map<RsPeerId,RsReputations::Opinion>::iterator it2 = reputation.mOpinions.find(from) ;
|
std::map<RsPeerId,RsOpinion>::iterator it2 = reputation.mOpinions.find(from) ;
|
||||||
|
|
||||||
if(it2 == reputation.mOpinions.end())
|
if(it2 == reputation.mOpinions.end())
|
||||||
{
|
{
|
||||||
if(new_opinion != RsReputations::OPINION_NEUTRAL)
|
if(new_opinion != RsOpinion::NEUTRAL)
|
||||||
{
|
{
|
||||||
reputation.mOpinions[from] = new_opinion; // filters potentially tweaked reputation score sent by friend
|
reputation.mOpinions[from] = new_opinion; // filters potentially tweaked reputation score sent by friend
|
||||||
updated = true ;
|
updated = true ;
|
||||||
@ -688,7 +692,7 @@ void p3GxsReputation::locked_updateOpinion(const RsPeerId& from,const RsGxsId& a
|
|||||||
{
|
{
|
||||||
old_opinion = it2->second ;
|
old_opinion = it2->second ;
|
||||||
|
|
||||||
if(new_opinion == RsReputations::OPINION_NEUTRAL)
|
if(new_opinion == RsOpinion::NEUTRAL)
|
||||||
{
|
{
|
||||||
reputation.mOpinions.erase(it2) ; // don't store when the opinion is neutral
|
reputation.mOpinions.erase(it2) ; // don't store when the opinion is neutral
|
||||||
updated = true ;
|
updated = true ;
|
||||||
@ -700,7 +704,8 @@ void p3GxsReputation::locked_updateOpinion(const RsPeerId& from,const RsGxsId& a
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(reputation.mOpinions.empty() && reputation.mOwnOpinion == RsReputations::OPINION_NEUTRAL)
|
if( reputation.mOpinions.empty() &&
|
||||||
|
reputation.mOwnOpinion == static_cast<int32_t>(RsOpinion::NEUTRAL) )
|
||||||
{
|
{
|
||||||
mReputations.erase(rit) ;
|
mReputations.erase(rit) ;
|
||||||
#ifdef DEBUG_REPUTATION
|
#ifdef DEBUG_REPUTATION
|
||||||
@ -766,9 +771,10 @@ bool p3GxsReputation::updateLatestUpdate(RsPeerId peerid,rstime_t latest_update)
|
|||||||
* Opinion
|
* Opinion
|
||||||
****/
|
****/
|
||||||
|
|
||||||
RsReputations::ReputationLevel p3GxsReputation::overallReputationLevel(const RsGxsId& id,uint32_t *identity_flags)
|
RsReputationLevel p3GxsReputation::overallReputationLevel(
|
||||||
|
const RsGxsId& id, uint32_t* identity_flags )
|
||||||
{
|
{
|
||||||
ReputationInfo info ;
|
RsReputationInfo info ;
|
||||||
getReputationInfo(id,RsPgpId(),info) ;
|
getReputationInfo(id,RsPgpId(),info) ;
|
||||||
|
|
||||||
RsPgpId owner_id ;
|
RsPgpId owner_id ;
|
||||||
@ -805,12 +811,14 @@ bool p3GxsReputation::getIdentityFlagsAndOwnerId(const RsGxsId& gxsid, uint32_t&
|
|||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool p3GxsReputation::getReputationInfo(const RsGxsId& gxsid, const RsPgpId& ownerNode, RsReputations::ReputationInfo& info, bool stamp)
|
bool p3GxsReputation::getReputationInfo(
|
||||||
|
const RsGxsId& gxsid, const RsPgpId& ownerNode, RsReputationInfo& info,
|
||||||
|
bool stamp )
|
||||||
{
|
{
|
||||||
if(gxsid.isNull())
|
if(gxsid.isNull())
|
||||||
return false ;
|
return false ;
|
||||||
|
|
||||||
rstime_t now = time(NULL) ;
|
rstime_t now = time(nullptr);
|
||||||
|
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
@ -822,8 +830,8 @@ bool p3GxsReputation::getReputationInfo(const RsGxsId& gxsid, const RsPgpId& own
|
|||||||
|
|
||||||
if(it == mReputations.end())
|
if(it == mReputations.end())
|
||||||
{
|
{
|
||||||
info.mOwnOpinion = RsReputations::OPINION_NEUTRAL ;
|
info.mOwnOpinion = RsOpinion::NEUTRAL ;
|
||||||
info.mFriendAverageScore = REPUTATION_THRESHOLD_DEFAULT ;
|
info.mFriendAverageScore = RS_REPUTATION_THRESHOLD_DEFAULT ;
|
||||||
info.mFriendsNegativeVotes = 0 ;
|
info.mFriendsNegativeVotes = 0 ;
|
||||||
info.mFriendsPositiveVotes = 0 ;
|
info.mFriendsPositiveVotes = 0 ;
|
||||||
|
|
||||||
@ -833,7 +841,9 @@ bool p3GxsReputation::getReputationInfo(const RsGxsId& gxsid, const RsPgpId& own
|
|||||||
{
|
{
|
||||||
Reputation& rep(it->second) ;
|
Reputation& rep(it->second) ;
|
||||||
|
|
||||||
info.mOwnOpinion = RsReputations::Opinion(rep.mOwnOpinion) ;
|
info.mOwnOpinion =
|
||||||
|
safe_convert_uint32t_to_opinion(
|
||||||
|
static_cast<uint32_t>(rep.mOwnOpinion) );
|
||||||
info.mFriendAverageScore = rep.mFriendAverage ;
|
info.mFriendAverageScore = rep.mFriendAverage ;
|
||||||
info.mFriendsNegativeVotes = rep.mFriendsNegative ;
|
info.mFriendsNegativeVotes = rep.mFriendsNegative ;
|
||||||
info.mFriendsPositiveVotes = rep.mFriendsPositive ;
|
info.mFriendsPositiveVotes = rep.mFriendsPositive ;
|
||||||
@ -853,18 +863,18 @@ bool p3GxsReputation::getReputationInfo(const RsGxsId& gxsid, const RsPgpId& own
|
|||||||
|
|
||||||
// 0 - check for own opinion. If positive or negative, it decides on the result
|
// 0 - check for own opinion. If positive or negative, it decides on the result
|
||||||
|
|
||||||
if(info.mOwnOpinion == RsReputations::OPINION_NEGATIVE)
|
if(info.mOwnOpinion == RsOpinion::NEGATIVE)
|
||||||
{
|
{
|
||||||
// own opinion is always read in priority
|
// own opinion is always read in priority
|
||||||
|
|
||||||
info.mOverallReputationLevel = RsReputations::REPUTATION_LOCALLY_NEGATIVE ;
|
info.mOverallReputationLevel = RsReputationLevel::LOCALLY_NEGATIVE;
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
if(info.mOwnOpinion == RsReputations::OPINION_POSITIVE)
|
if(info.mOwnOpinion == RsOpinion::POSITIVE)
|
||||||
{
|
{
|
||||||
// own opinion is always read in priority
|
// own opinion is always read in priority
|
||||||
|
|
||||||
info.mOverallReputationLevel = RsReputations::REPUTATION_LOCALLY_POSITIVE ;
|
info.mOverallReputationLevel = RsReputationLevel::LOCALLY_POSITIVE;
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -889,7 +899,7 @@ bool p3GxsReputation::getReputationInfo(const RsGxsId& gxsid, const RsPgpId& own
|
|||||||
#ifdef DEBUG_REPUTATION2
|
#ifdef DEBUG_REPUTATION2
|
||||||
std::cerr << "p3GxsReputations: identity " << gxsid << " is banned because owner node ID " << owner_id << " is banned (found in banned nodes list)." << std::endl;
|
std::cerr << "p3GxsReputations: identity " << gxsid << " is banned because owner node ID " << owner_id << " is banned (found in banned nodes list)." << std::endl;
|
||||||
#endif
|
#endif
|
||||||
info.mOverallReputationLevel = RsReputations::REPUTATION_LOCALLY_NEGATIVE ;
|
info.mOverallReputationLevel = RsReputationLevel::LOCALLY_NEGATIVE;
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
// also check the proxy
|
// also check the proxy
|
||||||
@ -899,17 +909,17 @@ bool p3GxsReputation::getReputationInfo(const RsGxsId& gxsid, const RsPgpId& own
|
|||||||
#ifdef DEBUG_REPUTATION2
|
#ifdef DEBUG_REPUTATION2
|
||||||
std::cerr << "p3GxsReputations: identity " << gxsid << " is banned because owner node ID " << owner_id << " is banned (found in proxy)." << std::endl;
|
std::cerr << "p3GxsReputations: identity " << gxsid << " is banned because owner node ID " << owner_id << " is banned (found in proxy)." << std::endl;
|
||||||
#endif
|
#endif
|
||||||
info.mOverallReputationLevel = RsReputations::REPUTATION_LOCALLY_NEGATIVE ;
|
info.mOverallReputationLevel = RsReputationLevel::LOCALLY_NEGATIVE;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
// 2 - now, our own opinion is neutral, which means we rely on what our friends tell
|
// 2 - now, our own opinion is neutral, which means we rely on what our friends tell
|
||||||
|
|
||||||
if(info.mFriendsPositiveVotes >= info.mFriendsNegativeVotes + mMinVotesForRemotelyPositive)
|
if(info.mFriendsPositiveVotes >= info.mFriendsNegativeVotes + mMinVotesForRemotelyPositive)
|
||||||
info.mOverallReputationLevel = RsReputations::REPUTATION_REMOTELY_POSITIVE ;
|
info.mOverallReputationLevel = RsReputationLevel::REMOTELY_POSITIVE;
|
||||||
else if(info.mFriendsPositiveVotes + mMinVotesForRemotelyNegative <= info.mFriendsNegativeVotes)
|
else if(info.mFriendsPositiveVotes + mMinVotesForRemotelyNegative <= info.mFriendsNegativeVotes)
|
||||||
info.mOverallReputationLevel = RsReputations::REPUTATION_REMOTELY_NEGATIVE ;
|
info.mOverallReputationLevel = RsReputationLevel::REMOTELY_NEGATIVE;
|
||||||
else
|
else
|
||||||
info.mOverallReputationLevel = RsReputations::REPUTATION_NEUTRAL ;
|
info.mOverallReputationLevel = RsReputationLevel::NEUTRAL;
|
||||||
|
|
||||||
#ifdef DEBUG_REPUTATION2
|
#ifdef DEBUG_REPUTATION2
|
||||||
std::cerr << " information present. OwnOp = " << info.mOwnOpinion << ", owner node=" << owner_id << ", overall score=" << info.mAssessment << std::endl;
|
std::cerr << " information present. OwnOp = " << info.mOwnOpinion << ", owner node=" << owner_id << ", overall score=" << info.mAssessment << std::endl;
|
||||||
@ -969,16 +979,20 @@ void p3GxsReputation::banNode(const RsPgpId& id,bool b)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RsReputationLevel p3GxsReputation::overallReputationLevel(const RsGxsId& id)
|
||||||
|
{ return overallReputationLevel(id, nullptr); }
|
||||||
|
|
||||||
bool p3GxsReputation::isNodeBanned(const RsPgpId& id)
|
bool p3GxsReputation::isNodeBanned(const RsPgpId& id)
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
return mBannedPgpIds.find(id) != mBannedPgpIds.end();
|
return mBannedPgpIds.find(id) != mBannedPgpIds.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool p3GxsReputation::isIdentityBanned(const RsGxsId &id)
|
bool p3GxsReputation::isIdentityBanned(const RsGxsId &id)
|
||||||
{
|
{
|
||||||
RsReputations::ReputationInfo info ;
|
RsReputationInfo info;
|
||||||
|
|
||||||
if(!getReputationInfo(id,RsPgpId(),info))
|
if(!getReputationInfo(id,RsPgpId(),info))
|
||||||
return false ;
|
return false ;
|
||||||
@ -986,10 +1000,11 @@ bool p3GxsReputation::isIdentityBanned(const RsGxsId &id)
|
|||||||
#ifdef DEBUG_REPUTATION
|
#ifdef DEBUG_REPUTATION
|
||||||
std::cerr << "isIdentityBanned(): returning " << (info.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE) << " for GXS id " << id << std::endl;
|
std::cerr << "isIdentityBanned(): returning " << (info.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE) << " for GXS id " << id << std::endl;
|
||||||
#endif
|
#endif
|
||||||
return info.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE ;
|
return info.mOverallReputationLevel == RsReputationLevel::LOCALLY_NEGATIVE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool p3GxsReputation::getOwnOpinion(const RsGxsId& gxsid, RsReputations::Opinion& opinion)
|
bool p3GxsReputation::getOwnOpinion(
|
||||||
|
const RsGxsId& gxsid, RsOpinion& opinion )
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_REPUTATION
|
#ifdef DEBUG_REPUTATION
|
||||||
std::cerr << "setOwnOpinion(): for GXS id " << gxsid << " to " << opinion << std::endl;
|
std::cerr << "setOwnOpinion(): for GXS id " << gxsid << " to " << opinion << std::endl;
|
||||||
@ -1000,19 +1015,21 @@ bool p3GxsReputation::getOwnOpinion(const RsGxsId& gxsid, RsReputations::Opinion
|
|||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
|
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RS_STACK_MUTEX(mReputationMtx);
|
||||||
|
|
||||||
std::map<RsGxsId, Reputation>::iterator rit = mReputations.find(gxsid);
|
std::map<RsGxsId, Reputation>::iterator rit = mReputations.find(gxsid);
|
||||||
|
|
||||||
if(rit != mReputations.end())
|
if(rit != mReputations.end())
|
||||||
opinion = RsReputations::Opinion(rit->second.mOwnOpinion) ;
|
opinion = safe_convert_uint32t_to_opinion(
|
||||||
else
|
static_cast<uint32_t>(rit->second.mOwnOpinion) );
|
||||||
opinion = RsReputations::OPINION_NEUTRAL ;
|
else
|
||||||
|
opinion = RsOpinion::NEUTRAL;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool p3GxsReputation::setOwnOpinion(const RsGxsId& gxsid, const RsReputations::Opinion& opinion)
|
bool p3GxsReputation::setOwnOpinion(
|
||||||
|
const RsGxsId& gxsid, RsOpinion opinion )
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_REPUTATION
|
#ifdef DEBUG_REPUTATION
|
||||||
std::cerr << "setOwnOpinion(): for GXS id " << gxsid << " to " << opinion << std::endl;
|
std::cerr << "setOwnOpinion(): for GXS id " << gxsid << " to " << opinion << std::endl;
|
||||||
@ -1022,8 +1039,8 @@ bool p3GxsReputation::setOwnOpinion(const RsGxsId& gxsid, const RsReputations::O
|
|||||||
std::cerr << " ID " << gxsid << " is rejected. Look for a bug in calling method." << std::endl;
|
std::cerr << " ID " << gxsid << " is rejected. Look for a bug in calling method." << std::endl;
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
|
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RS_STACK_MUTEX(mReputationMtx);
|
||||||
|
|
||||||
std::map<RsGxsId, Reputation>::iterator rit;
|
std::map<RsGxsId, Reputation>::iterator rit;
|
||||||
|
|
||||||
@ -1033,7 +1050,7 @@ bool p3GxsReputation::setOwnOpinion(const RsGxsId& gxsid, const RsReputations::O
|
|||||||
if (rit == mReputations.end())
|
if (rit == mReputations.end())
|
||||||
{
|
{
|
||||||
#warning csoler 2017-01-05: We should set the owner node id here.
|
#warning csoler 2017-01-05: We should set the owner node id here.
|
||||||
mReputations[gxsid] = Reputation(gxsid);
|
mReputations[gxsid] = Reputation();
|
||||||
rit = mReputations.find(gxsid);
|
rit = mReputations.find(gxsid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1041,7 +1058,7 @@ bool p3GxsReputation::setOwnOpinion(const RsGxsId& gxsid, const RsReputations::O
|
|||||||
Reputation &reputation = rit->second;
|
Reputation &reputation = rit->second;
|
||||||
if (reputation.mOwnOpinionTs != 0)
|
if (reputation.mOwnOpinionTs != 0)
|
||||||
{
|
{
|
||||||
if (reputation.mOwnOpinion == opinion)
|
if (reputation.mOwnOpinion == static_cast<int32_t>(opinion))
|
||||||
{
|
{
|
||||||
// if opinion is accurate, don't update.
|
// if opinion is accurate, don't update.
|
||||||
return false;
|
return false;
|
||||||
@ -1060,8 +1077,8 @@ bool p3GxsReputation::setOwnOpinion(const RsGxsId& gxsid, const RsReputations::O
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rstime_t now = time(NULL);
|
rstime_t now = time(nullptr);
|
||||||
reputation.mOwnOpinion = opinion;
|
reputation.mOwnOpinion = static_cast<int32_t>(opinion);
|
||||||
reputation.mOwnOpinionTs = now;
|
reputation.mOwnOpinionTs = now;
|
||||||
reputation.updateReputation();
|
reputation.updateReputation();
|
||||||
|
|
||||||
@ -1126,7 +1143,7 @@ bool p3GxsReputation::saveList(bool& cleanup, std::list<RsItem*> &savelist)
|
|||||||
item->mOwnerNodeId = rit->second.mOwnerNode;
|
item->mOwnerNodeId = rit->second.mOwnerNode;
|
||||||
item->mLastUsedTS = rit->second.mLastUsedTS;
|
item->mLastUsedTS = rit->second.mLastUsedTS;
|
||||||
|
|
||||||
std::map<RsPeerId, RsReputations::Opinion>::iterator oit;
|
std::map<RsPeerId, RsOpinion>::iterator oit;
|
||||||
for(oit = rit->second.mOpinions.begin(); oit != rit->second.mOpinions.end(); ++oit)
|
for(oit = rit->second.mOpinions.begin(); oit != rit->second.mOpinions.end(); ++oit)
|
||||||
{
|
{
|
||||||
// should be already limited.
|
// should be already limited.
|
||||||
@ -1492,15 +1509,16 @@ void Reputation::updateReputation()
|
|||||||
// accounts for all friends. Neutral opinions count for 1-1=0
|
// accounts for all friends. Neutral opinions count for 1-1=0
|
||||||
// because the average is performed over only accessible peers (not the total number) we need to shift to 1
|
// because the average is performed over only accessible peers (not the total number) we need to shift to 1
|
||||||
|
|
||||||
for(std::map<RsPeerId,RsReputations::Opinion>::const_iterator it(mOpinions.begin());it!=mOpinions.end();++it)
|
for( std::map<RsPeerId,RsOpinion>::const_iterator it(mOpinions.begin());
|
||||||
|
it != mOpinions.end(); ++it )
|
||||||
{
|
{
|
||||||
if( it->second == RsReputations::OPINION_NEGATIVE)
|
if( it->second == RsOpinion::NEGATIVE)
|
||||||
++mFriendsNegative ;
|
++mFriendsNegative ;
|
||||||
|
|
||||||
if( it->second == RsReputations::OPINION_POSITIVE)
|
if( it->second == RsOpinion::POSITIVE)
|
||||||
++mFriendsPositive ;
|
++mFriendsPositive ;
|
||||||
|
|
||||||
friend_total += it->second - 1 ;
|
friend_total += static_cast<int>(it->second) - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mOpinions.empty()) // includes the case of no friends!
|
if(mOpinions.empty()) // includes the case of no friends!
|
||||||
@ -1554,11 +1572,10 @@ void Reputation::updateReputation()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// now compute a bias for PGP-signed ids.
|
// now compute a bias for PGP-signed ids.
|
||||||
|
|
||||||
if(mOwnOpinion == RsReputations::OPINION_NEUTRAL)
|
if(mOwnOpinion == static_cast<int32_t>(RsOpinion::NEUTRAL))
|
||||||
mReputationScore = mFriendAverage ;
|
mReputationScore = mFriendAverage;
|
||||||
else
|
else mReputationScore = static_cast<float>(mOwnOpinion);
|
||||||
mReputationScore = (float)mOwnOpinion ;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void p3GxsReputation::debug_print()
|
void p3GxsReputation::debug_print()
|
||||||
@ -1567,19 +1584,22 @@ void p3GxsReputation::debug_print()
|
|||||||
std::cerr << " GXS ID data: " << std::endl;
|
std::cerr << " GXS ID data: " << std::endl;
|
||||||
std::cerr << std::dec ;
|
std::cerr << std::dec ;
|
||||||
|
|
||||||
std::map<RsGxsId,Reputation> rep_copy;
|
std::map<RsGxsId,Reputation> rep_copy;
|
||||||
|
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RS_STACK_MUTEX(mReputationMtx);
|
||||||
rep_copy = mReputations ;
|
rep_copy = mReputations;
|
||||||
}
|
}
|
||||||
rstime_t now = time(NULL) ;
|
|
||||||
|
|
||||||
for(std::map<RsGxsId,Reputation>::const_iterator it(rep_copy.begin());it!=rep_copy.end();++it)
|
rstime_t now = time(nullptr);
|
||||||
|
|
||||||
|
|
||||||
|
for( std::map<RsGxsId,Reputation>::const_iterator it(rep_copy.begin());
|
||||||
|
it != rep_copy.end(); ++it )
|
||||||
{
|
{
|
||||||
RsReputations::ReputationInfo info ;
|
RsReputationInfo info;
|
||||||
getReputationInfo(it->first,RsPgpId(),info,false) ;
|
getReputationInfo(it->first, RsPgpId(), info, false);
|
||||||
uint32_t lev = info.mOverallReputationLevel;
|
uint32_t lev = static_cast<uint32_t>(info.mOverallReputationLevel);
|
||||||
|
|
||||||
std::cerr << " " << it->first << ": own: " << it->second.mOwnOpinion
|
std::cerr << " " << it->first << ": own: " << it->second.mOwnOpinion
|
||||||
<< ", PGP id=" << it->second.mOwnerNode
|
<< ", PGP id=" << it->second.mOwnerNode
|
||||||
@ -1596,7 +1616,7 @@ std::map<RsGxsId,Reputation> rep_copy;
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
RsStackMutex stack(mReputationMtx); /****** LOCKED MUTEX *******/
|
RS_STACK_MUTEX(mReputationMtx);
|
||||||
std::cerr << " Banned RS nodes by ID: " << std::endl;
|
std::cerr << " Banned RS nodes by ID: " << std::endl;
|
||||||
|
|
||||||
for(std::map<RsPgpId,BannedNodeInfo>::const_iterator it(mBannedPgpIds.begin());it!=mBannedPgpIds.end();++it)
|
for(std::map<RsPgpId,BannedNodeInfo>::const_iterator it(mBannedPgpIds.begin());it!=mBannedPgpIds.end();++it)
|
||||||
|
@ -64,15 +64,17 @@ struct BannedNodeInfo
|
|||||||
class Reputation
|
class Reputation
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Reputation()
|
Reputation() :
|
||||||
:mOwnOpinion(RsReputations::OPINION_NEUTRAL), mOwnOpinionTs(0),mFriendAverage(1.0f), mReputationScore(RsReputations::OPINION_NEUTRAL),mIdentityFlags(0){ }
|
mOwnOpinion(static_cast<int32_t>(RsOpinion::NEUTRAL)), mOwnOpinionTs(0),
|
||||||
|
mFriendAverage(1.0f),
|
||||||
Reputation(const RsGxsId& /*about*/)
|
/* G10h4ck: TODO shouln't this be initialized with
|
||||||
:mOwnOpinion(RsReputations::OPINION_NEUTRAL), mOwnOpinionTs(0),mFriendAverage(1.0f), mReputationScore(RsReputations::OPINION_NEUTRAL),mIdentityFlags(0){ }
|
* RsReputation::NEUTRAL or UNKOWN? */
|
||||||
|
mReputationScore(static_cast<float>(RsOpinion::NEUTRAL)),
|
||||||
|
mIdentityFlags(0) {}
|
||||||
|
|
||||||
void updateReputation();
|
void updateReputation();
|
||||||
|
|
||||||
std::map<RsPeerId, RsReputations::Opinion> mOpinions;
|
std::map<RsPeerId, RsOpinion> mOpinions;
|
||||||
int32_t mOwnOpinion;
|
int32_t mOwnOpinion;
|
||||||
rstime_t mOwnOpinionTs;
|
rstime_t mOwnOpinionTs;
|
||||||
|
|
||||||
@ -91,11 +93,6 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
//!The p3GxsReputation service.
|
//!The p3GxsReputation service.
|
||||||
/**
|
|
||||||
*
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
class p3GxsReputation: public p3Service, public p3Config, public RsGixsReputation, public RsReputations /* , public pqiMonitor */
|
class p3GxsReputation: public p3Service, public p3Config, public RsGixsReputation, public RsReputations /* , public pqiMonitor */
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -103,20 +100,26 @@ public:
|
|||||||
virtual RsServiceInfo getServiceInfo();
|
virtual RsServiceInfo getServiceInfo();
|
||||||
|
|
||||||
/***** Interface for RsReputations *****/
|
/***** Interface for RsReputations *****/
|
||||||
virtual bool setOwnOpinion(const RsGxsId& key_id, const Opinion& op) ;
|
virtual bool setOwnOpinion(const RsGxsId& key_id, RsOpinion op);
|
||||||
virtual bool getOwnOpinion(const RsGxsId& key_id, Opinion& op) ;
|
virtual bool getOwnOpinion(const RsGxsId& key_id, RsOpinion& op) ;
|
||||||
virtual bool getReputationInfo(const RsGxsId& id, const RsPgpId &ownerNode, ReputationInfo& info,bool stamp=true) ;
|
virtual bool getReputationInfo(
|
||||||
|
const RsGxsId& id, const RsPgpId& ownerNode, RsReputationInfo& info,
|
||||||
|
bool stamp = true );
|
||||||
virtual bool isIdentityBanned(const RsGxsId& id) ;
|
virtual bool isIdentityBanned(const RsGxsId& id) ;
|
||||||
|
|
||||||
virtual bool isNodeBanned(const RsPgpId& id);
|
virtual bool isNodeBanned(const RsPgpId& id);
|
||||||
virtual void banNode(const RsPgpId& id,bool b) ;
|
virtual void banNode(const RsPgpId& id,bool b) ;
|
||||||
virtual ReputationLevel overallReputationLevel(const RsGxsId& id,uint32_t *identity_flags=NULL);
|
|
||||||
|
|
||||||
virtual void setNodeAutoPositiveOpinionForContacts(bool b) ;
|
RsReputationLevel overallReputationLevel(const RsGxsId& id) override;
|
||||||
virtual bool nodeAutoPositiveOpinionForContacts() ;
|
|
||||||
|
|
||||||
virtual void setRememberDeletedNodesThreshold(uint32_t days) ;
|
virtual RsReputationLevel overallReputationLevel(
|
||||||
virtual uint32_t rememberDeletedNodesThreshold() ;
|
const RsGxsId& id, uint32_t* identity_flags );
|
||||||
|
|
||||||
|
virtual void setAutoPositiveOpinionForContacts(bool b) ;
|
||||||
|
virtual bool autoPositiveOpinionForContacts() ;
|
||||||
|
|
||||||
|
virtual void setRememberBannedIdThreshold(uint32_t days) ;
|
||||||
|
virtual uint32_t rememberBannedIdThreshold() ;
|
||||||
|
|
||||||
uint32_t thresholdForRemotelyNegativeReputation();
|
uint32_t thresholdForRemotelyNegativeReputation();
|
||||||
uint32_t thresholdForRemotelyPositiveReputation();
|
uint32_t thresholdForRemotelyPositiveReputation();
|
||||||
@ -149,7 +152,8 @@ private:
|
|||||||
void updateBannedNodesProxy();
|
void updateBannedNodesProxy();
|
||||||
|
|
||||||
// internal update of data. Takes care of cleaning empty boxes.
|
// internal update of data. Takes care of cleaning empty boxes.
|
||||||
void locked_updateOpinion(const RsPeerId &from, const RsGxsId &about, RsReputations::Opinion op);
|
void locked_updateOpinion(
|
||||||
|
const RsPeerId& from, const RsGxsId& about, RsOpinion op);
|
||||||
bool loadReputationSet(RsGxsReputationSetItem *item, const std::set<RsPeerId> &peerSet);
|
bool loadReputationSet(RsGxsReputationSetItem *item, const std::set<RsPeerId> &peerSet);
|
||||||
#ifdef TO_REMOVE
|
#ifdef TO_REMOVE
|
||||||
bool loadReputationSet_deprecated3(RsGxsReputationSetItem_deprecated3 *item, const std::set<RsPeerId> &peerSet);
|
bool loadReputationSet_deprecated3(RsGxsReputationSetItem_deprecated3 *item, const std::set<RsPeerId> &peerSet);
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
* *
|
* *
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
#include "services/p3idservice.h"
|
#include "services/p3idservice.h"
|
||||||
#include "pgp/pgpauxutils.h"
|
#include "pgp/pgpauxutils.h"
|
||||||
@ -207,6 +208,32 @@ void p3IdService::setNes(RsNetworkExchangeService *nes)
|
|||||||
mNes = nes;
|
mNes = nes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool p3IdService::getIdentitiesInfo(
|
||||||
|
const std::set<RsGxsId>& ids, std::vector<RsGxsIdGroup>& idsInfo )
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
|
||||||
|
RsTokReqOptions opts;
|
||||||
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_DATA;
|
||||||
|
|
||||||
|
std::list<RsGxsGroupId> idsList;
|
||||||
|
for (auto&& id : ids) idsList.push_back(RsGxsGroupId(id));
|
||||||
|
|
||||||
|
if( !requestGroupInfo(token, opts, idsList)
|
||||||
|
|| waitToken(token) != RsTokenService::COMPLETE ) return false;
|
||||||
|
return getGroupData(token, idsInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3IdService::getIdentitiesSummaries(std::list<RsGroupMetaData>& ids)
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
RsTokReqOptions opts;
|
||||||
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_META;
|
||||||
|
if( !requestGroupInfo(token, opts)
|
||||||
|
|| waitToken(token) != RsTokenService::COMPLETE ) return false;
|
||||||
|
return getGroupSummary(token, ids);
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t p3IdService::idAuthenPolicy()
|
uint32_t p3IdService::idAuthenPolicy()
|
||||||
{
|
{
|
||||||
uint32_t policy = 0;
|
uint32_t policy = 0;
|
||||||
@ -687,11 +714,12 @@ bool p3IdService::getIdDetails(const RsGxsId &id, RsIdentityDetails &details)
|
|||||||
// This step is needed, because p3GxsReputation does not know all identities, and might not have any data for
|
// This step is needed, because p3GxsReputation does not know all identities, and might not have any data for
|
||||||
// the ones in the contact list. So we change them on demand.
|
// the ones in the contact list. So we change them on demand.
|
||||||
|
|
||||||
if(is_a_contact && rsReputations->nodeAutoPositiveOpinionForContacts())
|
if(is_a_contact && rsReputations->autoPositiveOpinionForContacts())
|
||||||
{
|
{
|
||||||
RsReputations::Opinion op ;
|
RsOpinion op;
|
||||||
if(rsReputations->getOwnOpinion(id,op) && op == RsReputations::OPINION_NEUTRAL)
|
if( rsReputations->getOwnOpinion(id,op) &&
|
||||||
rsReputations->setOwnOpinion(id,RsReputations::OPINION_POSITIVE) ;
|
op == RsOpinion::NEUTRAL )
|
||||||
|
rsReputations->setOwnOpinion(id, RsOpinion::POSITIVE);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::map<RsGxsId,keyTSInfo>::const_iterator it = mKeysTS.find(id) ;
|
std::map<RsGxsId,keyTSInfo>::const_iterator it = mKeysTS.find(id) ;
|
||||||
@ -727,6 +755,46 @@ bool p3IdService::isOwnId(const RsGxsId& id)
|
|||||||
|
|
||||||
return std::find(mOwnIds.begin(),mOwnIds.end(),id) != mOwnIds.end() ;
|
return std::find(mOwnIds.begin(),mOwnIds.end(),id) != mOwnIds.end() ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool p3IdService::getOwnSignedIds(std::vector<RsGxsId> ids)
|
||||||
|
{
|
||||||
|
ids.clear();
|
||||||
|
|
||||||
|
std::chrono::seconds maxWait(5);
|
||||||
|
auto timeout = std::chrono::steady_clock::now() + maxWait;
|
||||||
|
while( !ownIdsAreLoaded() && std::chrono::steady_clock::now() < timeout )
|
||||||
|
std::this_thread::sleep_for(std::chrono::milliseconds(100));
|
||||||
|
|
||||||
|
if(ownIdsAreLoaded())
|
||||||
|
{
|
||||||
|
RS_STACK_MUTEX(mIdMtx);
|
||||||
|
ids.reserve(mOwnSignedIds.size());
|
||||||
|
ids.insert(ids.end(), mOwnSignedIds.begin(), mOwnSignedIds.end());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3IdService::getOwnPseudonimousIds(std::vector<RsGxsId> ids)
|
||||||
|
{
|
||||||
|
ids.clear();
|
||||||
|
std::vector<RsGxsId> signedV;
|
||||||
|
|
||||||
|
// this implicitely ensure ids are already loaded ;)
|
||||||
|
if(!getOwnSignedIds(signedV)) return false;
|
||||||
|
std::set<RsGxsId> signedS(signedV.begin(), signedV.end());
|
||||||
|
|
||||||
|
{
|
||||||
|
RS_STACK_MUTEX(mIdMtx);
|
||||||
|
std::copy_if(mOwnIds.begin(), mOwnIds.end(), ids.end(),
|
||||||
|
[&](const RsGxsId& id) {return !signedS.count(id);});
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool p3IdService::getOwnIds(std::list<RsGxsId> &ownIds,bool signed_only)
|
bool p3IdService::getOwnIds(std::list<RsGxsId> &ownIds,bool signed_only)
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
RsStackMutex stack(mIdMtx); /********** STACK LOCKED MTX ******/
|
||||||
@ -742,6 +810,11 @@ bool p3IdService::getOwnIds(std::list<RsGxsId> &ownIds,bool signed_only)
|
|||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool p3IdService::identityToBase64( const RsGxsId& id,
|
||||||
|
std::string& base64String )
|
||||||
|
{ return serialiseIdentityToMemory(id, base64String); }
|
||||||
|
|
||||||
bool p3IdService::serialiseIdentityToMemory( const RsGxsId& id,
|
bool p3IdService::serialiseIdentityToMemory( const RsGxsId& id,
|
||||||
std::string& radix_string )
|
std::string& radix_string )
|
||||||
{
|
{
|
||||||
@ -803,6 +876,10 @@ void p3IdService::handle_get_serialized_grp(uint32_t token)
|
|||||||
mSerialisedIdentities[RsGxsId(id)] = s ;
|
mSerialisedIdentities[RsGxsId(id)] = s ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool p3IdService::identityFromBase64(
|
||||||
|
const std::string& base64String, RsGxsId& id )
|
||||||
|
{ return deserialiseIdentityFromMemory(base64String, &id); }
|
||||||
|
|
||||||
bool p3IdService::deserialiseIdentityFromMemory(const std::string& radix_string,
|
bool p3IdService::deserialiseIdentityFromMemory(const std::string& radix_string,
|
||||||
RsGxsId* id /* = nullptr */)
|
RsGxsId* id /* = nullptr */)
|
||||||
{
|
{
|
||||||
@ -826,6 +903,47 @@ bool p3IdService::deserialiseIdentityFromMemory(const std::string& radix_string,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool p3IdService::createIdentity(
|
||||||
|
RsGxsId& id,
|
||||||
|
const std::string& name, const RsGxsImage& avatar,
|
||||||
|
bool pseudonimous, const std::string& pgpPassword)
|
||||||
|
{
|
||||||
|
if(!pgpPassword.empty())
|
||||||
|
std::cerr<< __PRETTY_FUNCTION__ << " Warning! PGP Password handling "
|
||||||
|
<< "not implemented yet!" << std::endl;
|
||||||
|
|
||||||
|
RsIdentityParameters params;
|
||||||
|
params.isPgpLinked = !pseudonimous;
|
||||||
|
params.nickname = name;
|
||||||
|
params.mImage = avatar;
|
||||||
|
|
||||||
|
uint32_t token;
|
||||||
|
if(!createIdentity(token, params))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << " Error! Failed creating group."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(waitToken(token) != RsTokenService::COMPLETE)
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << " Error! GXS operation failed."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
RsGroupMetaData meta;
|
||||||
|
if(!RsGenExchange::getPublishedGroupMeta(token, meta))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Failure getting updated "
|
||||||
|
<< " group data." << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
id = RsGxsId(meta.mGroupId);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool p3IdService::createIdentity(uint32_t& token, RsIdentityParameters ¶ms)
|
bool p3IdService::createIdentity(uint32_t& token, RsIdentityParameters ¶ms)
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -863,6 +981,26 @@ bool p3IdService::createIdentity(uint32_t& token, RsIdentityParameters ¶ms)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool p3IdService::updateIdentity(RsGxsIdGroup& identityData)
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
if(!updateGroup(token, identityData))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Failed updating group."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(waitToken(token) != RsTokenService::COMPLETE)
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! GXS operation failed."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool p3IdService::updateIdentity(uint32_t& token, RsGxsIdGroup &group)
|
bool p3IdService::updateIdentity(uint32_t& token, RsGxsIdGroup &group)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_IDS
|
#ifdef DEBUG_IDS
|
||||||
@ -876,6 +1014,27 @@ bool p3IdService::updateIdentity(uint32_t& token, RsGxsIdGroup &group)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool p3IdService::deleteIdentity(RsGxsId& id)
|
||||||
|
{
|
||||||
|
uint32_t token;
|
||||||
|
RsGxsGroupId grouId = RsGxsGroupId(id);
|
||||||
|
if(!deleteGroup(token, grouId))
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! Failed deleting group."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(waitToken(token) != RsTokenService::COMPLETE)
|
||||||
|
{
|
||||||
|
std::cerr << __PRETTY_FUNCTION__ << "Error! GXS operation failed."
|
||||||
|
<< std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool p3IdService::deleteIdentity(uint32_t& token, RsGxsIdGroup &group)
|
bool p3IdService::deleteIdentity(uint32_t& token, RsGxsIdGroup &group)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_IDS
|
#ifdef DEBUG_IDS
|
||||||
@ -883,7 +1042,7 @@ bool p3IdService::deleteIdentity(uint32_t& token, RsGxsIdGroup &group)
|
|||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
deleteGroup(token, group);
|
deleteGroup(token, group.mMeta.mGroupId);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -1012,10 +1171,10 @@ bool p3IdService::requestKey(const RsGxsId &id, const std::list<RsPeerId>& peers
|
|||||||
std::cerr << "p3IdService::requesting key " << id <<std::endl;
|
std::cerr << "p3IdService::requesting key " << id <<std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
RsReputations::ReputationInfo info ;
|
RsReputationInfo info;
|
||||||
rsReputations->getReputationInfo(id,RsPgpId(),info) ;
|
rsReputations->getReputationInfo(id,RsPgpId(),info) ;
|
||||||
|
|
||||||
if(info.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( info.mOverallReputationLevel == RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
std::cerr << "(II) not requesting Key " << id << " because it has been banned." << std::endl;
|
std::cerr << "(II) not requesting Key " << id << " because it has been banned." << std::endl;
|
||||||
|
|
||||||
@ -1796,16 +1955,16 @@ bool p3IdService::updateGroup(uint32_t& token, RsGxsIdGroup &group)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool p3IdService::deleteGroup(uint32_t& token, RsGxsIdGroup &group)
|
bool p3IdService::deleteGroup(uint32_t& token, RsGxsGroupId& groupId)
|
||||||
{
|
{
|
||||||
RsGxsId id(group.mMeta.mGroupId);
|
RsGxsId id(groupId);
|
||||||
|
|
||||||
#ifdef DEBUG_IDS
|
#ifdef DEBUG_IDS
|
||||||
std::cerr << "p3IdService::deleteGroup() Deleting RsGxsId: " << id;
|
std::cerr << "p3IdService::deleteGroup() Deleting RsGxsId: " << id;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
RsGenExchange::deleteGroup(token,group.mMeta.mGroupId);
|
RsGenExchange::deleteGroup(token, groupId);
|
||||||
|
|
||||||
// if its in the cache - clear it.
|
// if its in the cache - clear it.
|
||||||
{
|
{
|
||||||
|
@ -215,9 +215,8 @@ struct SerialisedIdentityStruct
|
|||||||
rstime_t mLastUsageTS;
|
rstime_t mLastUsageTS;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Not sure exactly what should be inherited here?
|
// We cache all identities, and provide alternative (instantaneous)
|
||||||
// Chris - please correct as necessary.
|
// functions to extract info, rather than the horrible Token system.
|
||||||
|
|
||||||
class p3IdService: public RsGxsIdExchange, public RsIdentity, public GxsTokenQueue, public RsTickEvent, public p3Config
|
class p3IdService: public RsGxsIdExchange, public RsIdentity, public GxsTokenQueue, public RsTickEvent, public p3Config
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -239,6 +238,13 @@ public:
|
|||||||
|
|
||||||
/* Data Specific Interface */
|
/* Data Specific Interface */
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool getIdentitiesInfo(const std::set<RsGxsId>& ids,
|
||||||
|
std::vector<RsGxsIdGroup>& idsInfo ) override;
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool getIdentitiesSummaries(std::list<RsGroupMetaData>& ids) override;
|
||||||
|
|
||||||
// These are exposed via RsIdentity.
|
// These are exposed via RsIdentity.
|
||||||
virtual bool getGroupData(const uint32_t &token, std::vector<RsGxsIdGroup> &groups);
|
virtual bool getGroupData(const uint32_t &token, std::vector<RsGxsIdGroup> &groups);
|
||||||
virtual bool getGroupSerializedData(const uint32_t &token, std::map<RsGxsId,std::string>& serialized_groups);
|
virtual bool getGroupSerializedData(const uint32_t &token, std::map<RsGxsId,std::string>& serialized_groups);
|
||||||
@ -248,7 +254,7 @@ public:
|
|||||||
// These are local - and not exposed via RsIdentity.
|
// These are local - and not exposed via RsIdentity.
|
||||||
virtual bool createGroup(uint32_t& token, RsGxsIdGroup &group);
|
virtual bool createGroup(uint32_t& token, RsGxsIdGroup &group);
|
||||||
virtual bool updateGroup(uint32_t& token, RsGxsIdGroup &group);
|
virtual bool updateGroup(uint32_t& token, RsGxsIdGroup &group);
|
||||||
virtual bool deleteGroup(uint32_t& token, RsGxsIdGroup &group);
|
virtual bool deleteGroup(uint32_t& token, RsGxsGroupId& group);
|
||||||
//virtual bool createMsg(uint32_t& token, RsGxsIdOpinion &opinion);
|
//virtual bool createMsg(uint32_t& token, RsGxsIdOpinion &opinion);
|
||||||
|
|
||||||
/**************** RsIdentity External Interface.
|
/**************** RsIdentity External Interface.
|
||||||
@ -263,12 +269,28 @@ public:
|
|||||||
//virtual bool getNickname(const RsGxsId &id, std::string &nickname);
|
//virtual bool getNickname(const RsGxsId &id, std::string &nickname);
|
||||||
virtual bool getIdDetails(const RsGxsId &id, RsIdentityDetails &details);
|
virtual bool getIdDetails(const RsGxsId &id, RsIdentityDetails &details);
|
||||||
|
|
||||||
//
|
RS_DEPRECATED_FOR(RsReputations)
|
||||||
virtual bool submitOpinion(uint32_t& token, const RsGxsId &id,
|
virtual bool submitOpinion(uint32_t& token, const RsGxsId &id,
|
||||||
bool absOpinion, int score);
|
bool absOpinion, int score);
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
virtual bool createIdentity(
|
||||||
|
RsGxsId& id,
|
||||||
|
const std::string& name, const RsGxsImage& avatar = RsGxsImage(),
|
||||||
|
bool pseudonimous = true, const std::string& pgpPassword = "" ) override;
|
||||||
|
|
||||||
virtual bool createIdentity(uint32_t& token, RsIdentityParameters ¶ms);
|
virtual bool createIdentity(uint32_t& token, RsIdentityParameters ¶ms);
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool updateIdentity(RsGxsIdGroup& identityData) override;
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
virtual bool updateIdentity(uint32_t& token, RsGxsIdGroup &group);
|
virtual bool updateIdentity(uint32_t& token, RsGxsIdGroup &group);
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool deleteIdentity(RsGxsId& id) override;
|
||||||
|
|
||||||
|
RS_DEPRECATED
|
||||||
virtual bool deleteIdentity(uint32_t& token, RsGxsIdGroup &group);
|
virtual bool deleteIdentity(uint32_t& token, RsGxsIdGroup &group);
|
||||||
|
|
||||||
virtual void setDeleteBannedNodesThreshold(uint32_t days) ;
|
virtual void setDeleteBannedNodesThreshold(uint32_t days) ;
|
||||||
@ -289,6 +311,12 @@ public:
|
|||||||
|
|
||||||
/**************** RsGixs Implementation ***************/
|
/**************** RsGixs Implementation ***************/
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool getOwnSignedIds(std::vector<RsGxsId> ids) override;
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool getOwnPseudonimousIds(std::vector<RsGxsId> ids) override;
|
||||||
|
|
||||||
virtual bool getOwnIds(std::list<RsGxsId> &ownIds, bool signed_only = false);
|
virtual bool getOwnIds(std::list<RsGxsId> &ownIds, bool signed_only = false);
|
||||||
|
|
||||||
//virtual bool getPublicKey(const RsGxsId &id, RsTlvSecurityKey &key) ;
|
//virtual bool getPublicKey(const RsGxsId &id, RsTlvSecurityKey &key) ;
|
||||||
@ -350,6 +378,15 @@ public:
|
|||||||
const RsIdentityUsage &use_info );
|
const RsIdentityUsage &use_info );
|
||||||
virtual bool requestPrivateKey(const RsGxsId &id);
|
virtual bool requestPrivateKey(const RsGxsId &id);
|
||||||
|
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool identityToBase64( const RsGxsId& id,
|
||||||
|
std::string& base64String ) override;
|
||||||
|
|
||||||
|
/// @see RsIdentity
|
||||||
|
bool identityFromBase64( const std::string& base64String,
|
||||||
|
RsGxsId& id ) override;
|
||||||
|
|
||||||
virtual bool serialiseIdentityToMemory(const RsGxsId& id,
|
virtual bool serialiseIdentityToMemory(const RsGxsId& id,
|
||||||
std::string& radix_string);
|
std::string& radix_string);
|
||||||
virtual bool deserialiseIdentityFromMemory(const std::string& radix_string,
|
virtual bool deserialiseIdentityFromMemory(const std::string& radix_string,
|
||||||
@ -599,7 +636,9 @@ private:
|
|||||||
rstime_t mLastKeyCleaningTime ;
|
rstime_t mLastKeyCleaningTime ;
|
||||||
rstime_t mLastConfigUpdate ;
|
rstime_t mLastConfigUpdate ;
|
||||||
|
|
||||||
bool mOwnIdsLoaded ;
|
bool mOwnIdsLoaded;
|
||||||
|
bool ownIdsAreLoaded() { RS_STACK_MUTEX(mIdMtx); return mOwnIdsLoaded; }
|
||||||
|
|
||||||
bool mAutoAddFriendsIdentitiesAsContacts;
|
bool mAutoAddFriendsIdentitiesAsContacts;
|
||||||
uint32_t mMaxKeepKeysBanned ;
|
uint32_t mMaxKeepKeysBanned ;
|
||||||
};
|
};
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#endif
|
#endif
|
||||||
#include <ctime> // Added for comfort of users of this util header
|
#include <ctime> // Added for comfort of users of this util header
|
||||||
|
#include "util/rsdeprecate.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Safer alternative to time_t.
|
* Safer alternative to time_t.
|
||||||
@ -47,7 +48,7 @@ namespace rstime {
|
|||||||
/*!
|
/*!
|
||||||
* \brief This is a cross-system definition of usleep, which accepts any 32 bits number of micro-seconds.
|
* \brief This is a cross-system definition of usleep, which accepts any 32 bits number of micro-seconds.
|
||||||
*/
|
*/
|
||||||
|
RS_DEPRECATED_FOR("std::this_thread::sleep_for")
|
||||||
int rs_usleep(uint32_t micro_seconds);
|
int rs_usleep(uint32_t micro_seconds);
|
||||||
|
|
||||||
/* Use this class to measure and display time duration of a given environment:
|
/* Use this class to measure and display time duration of a given environment:
|
||||||
|
@ -285,7 +285,7 @@ void IdDetailsDialog::insertIdDetails(uint32_t token)
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
RsReputations::ReputationInfo info ;
|
RsReputationInfo info;
|
||||||
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId),data.mPgpId,info) ;
|
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId),data.mPgpId,info) ;
|
||||||
|
|
||||||
#warning (csoler) Do we need to do this? This code is apparently not used.
|
#warning (csoler) Do we need to do this? This code is apparently not used.
|
||||||
@ -302,23 +302,34 @@ void IdDetailsDialog::insertIdDetails(uint32_t token)
|
|||||||
ui->label_positive->setText(QString::number(info.mFriendsPositiveVotes));
|
ui->label_positive->setText(QString::number(info.mFriendsPositiveVotes));
|
||||||
ui->label_negative->setText(QString::number(info.mFriendsNegativeVotes));
|
ui->label_negative->setText(QString::number(info.mFriendsNegativeVotes));
|
||||||
|
|
||||||
switch(info.mOverallReputationLevel)
|
switch(info.mOverallReputationLevel)
|
||||||
{
|
|
||||||
case RsReputations::REPUTATION_LOCALLY_POSITIVE: ui->overallOpinion_TF->setText(tr("Positive")) ; break ;
|
|
||||||
case RsReputations::REPUTATION_LOCALLY_NEGATIVE: ui->overallOpinion_TF->setText(tr("Negative (Banned by you)")) ; break ;
|
|
||||||
case RsReputations::REPUTATION_REMOTELY_POSITIVE: ui->overallOpinion_TF->setText(tr("Positive (according to your friends)")) ; break ;
|
|
||||||
case RsReputations::REPUTATION_REMOTELY_NEGATIVE: ui->overallOpinion_TF->setText(tr("Negative (according to your friends)")) ; break ;
|
|
||||||
default:
|
|
||||||
case RsReputations::REPUTATION_NEUTRAL: ui->overallOpinion_TF->setText(tr("Neutral")) ; break ;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch(info.mOwnOpinion)
|
|
||||||
{
|
{
|
||||||
case RsReputations::OPINION_NEGATIVE: ui->ownOpinion_CB->setCurrentIndex(0); break ;
|
case RsReputationLevel::LOCALLY_POSITIVE:
|
||||||
case RsReputations::OPINION_NEUTRAL : ui->ownOpinion_CB->setCurrentIndex(1); break ;
|
ui->overallOpinion_TF->setText(tr("Positive")); break;
|
||||||
case RsReputations::OPINION_POSITIVE: ui->ownOpinion_CB->setCurrentIndex(2); break ;
|
case RsReputationLevel::LOCALLY_NEGATIVE:
|
||||||
default:
|
ui->overallOpinion_TF->setText(tr("Negative (Banned by you)")); break;
|
||||||
std::cerr << "Unexpected value in own opinion: " << info.mOwnOpinion << std::endl;
|
case RsReputationLevel::REMOTELY_POSITIVE:
|
||||||
|
ui->overallOpinion_TF->setText(
|
||||||
|
tr("Positive (according to your friends)"));
|
||||||
|
break;
|
||||||
|
case RsReputationLevel::REMOTELY_NEGATIVE:
|
||||||
|
ui->overallOpinion_TF->setText(
|
||||||
|
tr("Negative (according to your friends)"));
|
||||||
|
break;
|
||||||
|
case RsReputationLevel::NEUTRAL: // fallthrough
|
||||||
|
default:
|
||||||
|
ui->overallOpinion_TF->setText(tr("Neutral")); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch(info.mOwnOpinion)
|
||||||
|
{
|
||||||
|
case RsOpinion::NEGATIVE: ui->ownOpinion_CB->setCurrentIndex(0); break;
|
||||||
|
case RsOpinion::NEUTRAL : ui->ownOpinion_CB->setCurrentIndex(1); break;
|
||||||
|
case RsOpinion::POSITIVE: ui->ownOpinion_CB->setCurrentIndex(2); break;
|
||||||
|
default:
|
||||||
|
std::cerr << "Unexpected value in own opinion: "
|
||||||
|
<< static_cast<uint32_t>(info.mOwnOpinion) << std::endl;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -330,19 +341,19 @@ void IdDetailsDialog::modifyReputation()
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
RsGxsId id(ui->lineEdit_KeyId->text().toStdString());
|
RsGxsId id(ui->lineEdit_KeyId->text().toStdString());
|
||||||
|
|
||||||
RsReputations::Opinion op ;
|
|
||||||
|
|
||||||
switch(ui->ownOpinion_CB->currentIndex())
|
RsOpinion op;
|
||||||
{
|
|
||||||
case 0: op = RsReputations::OPINION_NEGATIVE ; break ;
|
switch(ui->ownOpinion_CB->currentIndex())
|
||||||
case 1: op = RsReputations::OPINION_NEUTRAL ; break ;
|
{
|
||||||
case 2: op = RsReputations::OPINION_POSITIVE ; break ;
|
case 0: op = RsOpinion::NEGATIVE; break;
|
||||||
default:
|
case 1: op = RsOpinion::NEUTRAL ; break;
|
||||||
std::cerr << "Wrong value from opinion combobox. Bug??" << std::endl;
|
case 2: op = RsOpinion::POSITIVE; break;
|
||||||
|
default:
|
||||||
}
|
std::cerr << "Wrong value from opinion combobox. Bug??" << std::endl;
|
||||||
rsReputations->setOwnOpinion(id,op) ;
|
break;
|
||||||
|
}
|
||||||
|
rsReputations->setOwnOpinion(id,op);
|
||||||
|
|
||||||
#ifdef ID_DEBUG
|
#ifdef ID_DEBUG
|
||||||
std::cerr << "IdDialog::modifyReputation() ID: " << id << " Mod: " << mod;
|
std::cerr << "IdDialog::modifyReputation() ID: " << id << " Mod: " << mod;
|
||||||
|
@ -344,7 +344,9 @@ IdDialog::IdDialog(QWidget *parent) :
|
|||||||
ui->idTreeWidget->setColumnWidth(RSID_COL_IDTYPE, 18 * fontWidth);
|
ui->idTreeWidget->setColumnWidth(RSID_COL_IDTYPE, 18 * fontWidth);
|
||||||
ui->idTreeWidget->setColumnWidth(RSID_COL_VOTES, 2 * fontWidth);
|
ui->idTreeWidget->setColumnWidth(RSID_COL_VOTES, 2 * fontWidth);
|
||||||
|
|
||||||
ui->idTreeWidget->setItemDelegateForColumn(RSID_COL_VOTES,new ReputationItemDelegate(RsReputations::ReputationLevel(0xff))) ;
|
ui->idTreeWidget->setItemDelegateForColumn(
|
||||||
|
RSID_COL_VOTES,
|
||||||
|
new ReputationItemDelegate(RsReputationLevel(0xff)));
|
||||||
|
|
||||||
/* Set header resize modes and initial section sizes */
|
/* Set header resize modes and initial section sizes */
|
||||||
QHeaderView * idheader = ui->idTreeWidget->header();
|
QHeaderView * idheader = ui->idTreeWidget->header();
|
||||||
@ -1444,8 +1446,9 @@ bool IdDialog::fillIdListItem(const RsGxsIdGroup& data, QTreeWidgetItem *&item,
|
|||||||
RsIdentityDetails idd ;
|
RsIdentityDetails idd ;
|
||||||
rsIdentity->getIdDetails(RsGxsId(data.mMeta.mGroupId),idd) ;
|
rsIdentity->getIdDetails(RsGxsId(data.mMeta.mGroupId),idd) ;
|
||||||
|
|
||||||
bool isBanned = idd.mReputation.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE;
|
bool isBanned = idd.mReputation.mOverallReputationLevel ==
|
||||||
uint32_t item_flags = 0 ;
|
RsReputationLevel::LOCALLY_NEGATIVE;
|
||||||
|
uint32_t item_flags = 0;
|
||||||
|
|
||||||
/* do filtering */
|
/* do filtering */
|
||||||
bool ok = false;
|
bool ok = false;
|
||||||
@ -1514,8 +1517,12 @@ bool IdDialog::fillIdListItem(const RsGxsIdGroup& data, QTreeWidgetItem *&item,
|
|||||||
|
|
||||||
item->setData(RSID_COL_KEYID, Qt::UserRole,QVariant(item_flags)) ;
|
item->setData(RSID_COL_KEYID, Qt::UserRole,QVariant(item_flags)) ;
|
||||||
item->setTextAlignment(RSID_COL_VOTES, Qt::AlignRight | Qt::AlignVCenter);
|
item->setTextAlignment(RSID_COL_VOTES, Qt::AlignRight | Qt::AlignVCenter);
|
||||||
item->setData(RSID_COL_VOTES,Qt::DecorationRole, idd.mReputation.mOverallReputationLevel);
|
item->setData(
|
||||||
item->setData(RSID_COL_VOTES,SortRole, idd.mReputation.mOverallReputationLevel);
|
RSID_COL_VOTES,Qt::DecorationRole,
|
||||||
|
static_cast<uint32_t>(idd.mReputation.mOverallReputationLevel));
|
||||||
|
item->setData(
|
||||||
|
RSID_COL_VOTES,SortRole,
|
||||||
|
static_cast<uint32_t>(idd.mReputation.mOverallReputationLevel));
|
||||||
|
|
||||||
if(isOwnId)
|
if(isOwnId)
|
||||||
{
|
{
|
||||||
@ -1910,7 +1917,7 @@ void IdDialog::insertIdDetails(uint32_t token)
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
RsReputations::ReputationInfo info ;
|
RsReputationInfo info;
|
||||||
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId),data.mPgpId,info) ;
|
rsReputations->getReputationInfo(RsGxsId(data.mMeta.mGroupId),data.mPgpId,info) ;
|
||||||
|
|
||||||
QString frep_string ;
|
QString frep_string ;
|
||||||
@ -1925,23 +1932,32 @@ void IdDialog::insertIdDetails(uint32_t token)
|
|||||||
ui->label_positive->setText(QString::number(info.mFriendsPositiveVotes));
|
ui->label_positive->setText(QString::number(info.mFriendsPositiveVotes));
|
||||||
ui->label_negative->setText(QString::number(info.mFriendsNegativeVotes));
|
ui->label_negative->setText(QString::number(info.mFriendsNegativeVotes));
|
||||||
|
|
||||||
switch(info.mOverallReputationLevel)
|
switch(info.mOverallReputationLevel)
|
||||||
{
|
|
||||||
case RsReputations::REPUTATION_LOCALLY_POSITIVE: ui->overallOpinion_TF->setText(tr("Positive")) ; break ;
|
|
||||||
case RsReputations::REPUTATION_LOCALLY_NEGATIVE: ui->overallOpinion_TF->setText(tr("Negative (Banned by you)")) ; break ;
|
|
||||||
case RsReputations::REPUTATION_REMOTELY_POSITIVE: ui->overallOpinion_TF->setText(tr("Positive (according to your friends)")) ; break ;
|
|
||||||
case RsReputations::REPUTATION_REMOTELY_NEGATIVE: ui->overallOpinion_TF->setText(tr("Negative (according to your friends)")) ; break ;
|
|
||||||
default:
|
|
||||||
case RsReputations::REPUTATION_NEUTRAL: ui->overallOpinion_TF->setText(tr("Neutral")) ; break ;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch(info.mOwnOpinion)
|
|
||||||
{
|
{
|
||||||
case RsReputations::OPINION_NEGATIVE: ui->ownOpinion_CB->setCurrentIndex(0); break ;
|
case RsReputationLevel::LOCALLY_POSITIVE:
|
||||||
case RsReputations::OPINION_NEUTRAL : ui->ownOpinion_CB->setCurrentIndex(1); break ;
|
ui->overallOpinion_TF->setText(tr("Positive")); break;
|
||||||
case RsReputations::OPINION_POSITIVE: ui->ownOpinion_CB->setCurrentIndex(2); break ;
|
case RsReputationLevel::LOCALLY_NEGATIVE:
|
||||||
default:
|
ui->overallOpinion_TF->setText(tr("Negative (Banned by you)")); break;
|
||||||
std::cerr << "Unexpected value in own opinion: " << info.mOwnOpinion << std::endl;
|
case RsReputationLevel::REMOTELY_POSITIVE:
|
||||||
|
ui->overallOpinion_TF->setText(tr("Positive (according to your friends)"));
|
||||||
|
break;
|
||||||
|
case RsReputationLevel::REMOTELY_NEGATIVE:
|
||||||
|
ui->overallOpinion_TF->setText(tr("Negative (according to your friends)"));
|
||||||
|
break;
|
||||||
|
case RsReputationLevel::NEUTRAL: // fallthrough
|
||||||
|
default:
|
||||||
|
ui->overallOpinion_TF->setText(tr("Neutral")) ; break ;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch(info.mOwnOpinion)
|
||||||
|
{
|
||||||
|
case RsOpinion::NEGATIVE: ui->ownOpinion_CB->setCurrentIndex(0); break;
|
||||||
|
case RsOpinion::NEUTRAL : ui->ownOpinion_CB->setCurrentIndex(1); break;
|
||||||
|
case RsOpinion::POSITIVE: ui->ownOpinion_CB->setCurrentIndex(2); break;
|
||||||
|
default:
|
||||||
|
std::cerr << "Unexpected value in own opinion: "
|
||||||
|
<< static_cast<uint32_t>(info.mOwnOpinion) << std::endl;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// now fill in usage cases
|
// now fill in usage cases
|
||||||
@ -2060,19 +2076,19 @@ void IdDialog::modifyReputation()
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
RsGxsId id(ui->lineEdit_KeyId->text().toStdString());
|
RsGxsId id(ui->lineEdit_KeyId->text().toStdString());
|
||||||
|
|
||||||
RsReputations::Opinion op ;
|
|
||||||
|
|
||||||
switch(ui->ownOpinion_CB->currentIndex())
|
RsOpinion op;
|
||||||
{
|
|
||||||
case 0: op = RsReputations::OPINION_NEGATIVE ; break ;
|
switch(ui->ownOpinion_CB->currentIndex())
|
||||||
case 1: op = RsReputations::OPINION_NEUTRAL ; break ;
|
{
|
||||||
case 2: op = RsReputations::OPINION_POSITIVE ; break ;
|
case 0: op = RsOpinion::NEGATIVE; break;
|
||||||
default:
|
case 1: op = RsOpinion::NEUTRAL ; break;
|
||||||
std::cerr << "Wrong value from opinion combobox. Bug??" << std::endl;
|
case 2: op = RsOpinion::POSITIVE; break;
|
||||||
|
default:
|
||||||
}
|
std::cerr << "Wrong value from opinion combobox. Bug??" << std::endl;
|
||||||
rsReputations->setOwnOpinion(id,op) ;
|
break;
|
||||||
|
}
|
||||||
|
rsReputations->setOwnOpinion(id,op);
|
||||||
|
|
||||||
#ifdef ID_DEBUG
|
#ifdef ID_DEBUG
|
||||||
std::cerr << "IdDialog::modifyReputation() ID: " << id << " Mod: " << op;
|
std::cerr << "IdDialog::modifyReputation() ID: " << id << " Mod: " << op;
|
||||||
@ -2386,17 +2402,12 @@ void IdDialog::IdListCustomPopupMenu( QPoint )
|
|||||||
|
|
||||||
switch(det.mReputation.mOwnOpinion)
|
switch(det.mReputation.mOwnOpinion)
|
||||||
{
|
{
|
||||||
case RsReputations::OPINION_NEGATIVE: ++n_negative_reputations ;
|
case RsOpinion::NEGATIVE: ++n_negative_reputations; break;
|
||||||
break ;
|
case RsOpinion::POSITIVE: ++n_positive_reputations; break;
|
||||||
|
case RsOpinion::NEUTRAL: ++n_neutral_reputations; break;
|
||||||
case RsReputations::OPINION_POSITIVE: ++n_positive_reputations ;
|
|
||||||
break ;
|
|
||||||
|
|
||||||
case RsReputations::OPINION_NEUTRAL: ++n_neutral_reputations ;
|
|
||||||
break ;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
++n_selected_items ;
|
++n_selected_items;
|
||||||
|
|
||||||
if(rsIdentity->isARegularContact(keyId))
|
if(rsIdentity->isARegularContact(keyId))
|
||||||
++n_is_a_contact ;
|
++n_is_a_contact ;
|
||||||
@ -2674,7 +2685,7 @@ void IdDialog::negativePerson()
|
|||||||
|
|
||||||
std::string Id = item->text(RSID_COL_KEYID).toStdString();
|
std::string Id = item->text(RSID_COL_KEYID).toStdString();
|
||||||
|
|
||||||
rsReputations->setOwnOpinion(RsGxsId(Id),RsReputations::OPINION_NEGATIVE) ;
|
rsReputations->setOwnOpinion(RsGxsId(Id), RsOpinion::NEGATIVE);
|
||||||
}
|
}
|
||||||
|
|
||||||
requestIdDetails();
|
requestIdDetails();
|
||||||
@ -2690,7 +2701,7 @@ void IdDialog::neutralPerson()
|
|||||||
|
|
||||||
std::string Id = item->text(RSID_COL_KEYID).toStdString();
|
std::string Id = item->text(RSID_COL_KEYID).toStdString();
|
||||||
|
|
||||||
rsReputations->setOwnOpinion(RsGxsId(Id),RsReputations::OPINION_NEUTRAL) ;
|
rsReputations->setOwnOpinion(RsGxsId(Id), RsOpinion::NEUTRAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
requestIdDetails();
|
requestIdDetails();
|
||||||
@ -2703,9 +2714,9 @@ void IdDialog::positivePerson()
|
|||||||
{
|
{
|
||||||
QTreeWidgetItem *item = *it ;
|
QTreeWidgetItem *item = *it ;
|
||||||
|
|
||||||
std::string Id = item->text(RSID_COL_KEYID).toStdString();
|
std::string Id = item->text(RSID_COL_KEYID).toStdString();
|
||||||
|
|
||||||
rsReputations->setOwnOpinion(RsGxsId(Id),RsReputations::OPINION_POSITIVE) ;
|
rsReputations->setOwnOpinion(RsGxsId(Id), RsOpinion::POSITIVE);
|
||||||
}
|
}
|
||||||
|
|
||||||
requestIdDetails();
|
requestIdDetails();
|
||||||
|
@ -300,9 +300,17 @@ void ChatLobbyDialog::initParticipantsContextMenu(QMenu *contextMnu, QList<RsGxs
|
|||||||
{
|
{
|
||||||
distantChatAct->setEnabled(true);
|
distantChatAct->setEnabled(true);
|
||||||
sendMessageAct->setEnabled(true);
|
sendMessageAct->setEnabled(true);
|
||||||
votePositiveAct->setEnabled(rsReputations->overallReputationLevel(gxsid) != RsReputations::REPUTATION_LOCALLY_POSITIVE);
|
votePositiveAct->setEnabled(
|
||||||
voteNeutralAct->setEnabled((rsReputations->overallReputationLevel(gxsid) == RsReputations::REPUTATION_LOCALLY_POSITIVE) || (rsReputations->overallReputationLevel(gxsid) == RsReputations::REPUTATION_LOCALLY_NEGATIVE) );
|
rsReputations->overallReputationLevel(gxsid) !=
|
||||||
voteNegativeAct->setEnabled(rsReputations->overallReputationLevel(gxsid) != RsReputations::REPUTATION_LOCALLY_NEGATIVE);
|
RsReputationLevel::LOCALLY_POSITIVE );
|
||||||
|
voteNeutralAct->setEnabled(
|
||||||
|
( rsReputations->overallReputationLevel(gxsid) ==
|
||||||
|
RsReputationLevel::LOCALLY_POSITIVE ) ||
|
||||||
|
( rsReputations->overallReputationLevel(gxsid) ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE ) );
|
||||||
|
voteNegativeAct->setEnabled(
|
||||||
|
rsReputations->overallReputationLevel(gxsid) !=
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE );
|
||||||
muteAct->setEnabled(true);
|
muteAct->setEnabled(true);
|
||||||
muteAct->setChecked(isParticipantMuted(gxsid));
|
muteAct->setChecked(isParticipantMuted(gxsid));
|
||||||
}
|
}
|
||||||
@ -319,16 +327,15 @@ void ChatLobbyDialog::voteParticipant()
|
|||||||
|
|
||||||
QList<RsGxsId> idList = act->data().value<QList<RsGxsId>>();
|
QList<RsGxsId> idList = act->data().value<QList<RsGxsId>>();
|
||||||
|
|
||||||
RsReputations::Opinion op = RsReputations::OPINION_NEUTRAL ;
|
RsOpinion op = RsOpinion::NEUTRAL;
|
||||||
if (act == votePositiveAct)
|
if (act == votePositiveAct) op = RsOpinion::POSITIVE;
|
||||||
op = RsReputations::OPINION_POSITIVE;
|
if (act == voteNegativeAct) op = RsOpinion::NEGATIVE;
|
||||||
if (act == voteNegativeAct)
|
|
||||||
op = RsReputations::OPINION_NEGATIVE;
|
|
||||||
|
|
||||||
for (QList<RsGxsId>::iterator item = idList.begin(); item != idList.end(); ++item)
|
for (QList<RsGxsId>::iterator item = idList.begin(); item != idList.end(); ++item)
|
||||||
{
|
{
|
||||||
rsReputations->setOwnOpinion(*item, op);
|
rsReputations->setOwnOpinion(*item, op);
|
||||||
std::cerr << "Giving opinion to GXS id " << *item << " to " << op << std::endl;
|
std::cerr << "Giving opinion to GXS id " << *item << " to "
|
||||||
|
<< static_cast<uint32_t>(op) << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
updateParticipantsList();
|
updateParticipantsList();
|
||||||
|
@ -84,7 +84,8 @@ void ReputationItemDelegate::paint(QPainter *painter, const QStyleOptionViewItem
|
|||||||
if(icon_index > mMaxLevelToDisplay)
|
if(icon_index > mMaxLevelToDisplay)
|
||||||
return ;
|
return ;
|
||||||
|
|
||||||
QIcon icon = GxsIdDetails::getReputationIcon(RsReputations::ReputationLevel(icon_index),0xff);
|
QIcon icon = GxsIdDetails::getReputationIcon(
|
||||||
|
RsReputationLevel(icon_index), 0xff );
|
||||||
|
|
||||||
QPixmap pix = icon.pixmap(r.size());
|
QPixmap pix = icon.pixmap(r.size());
|
||||||
|
|
||||||
@ -937,8 +938,9 @@ bool GxsIdDetails::MakeIdDesc(const RsGxsId &id, bool doIcons, QString &str, QLi
|
|||||||
|
|
||||||
QString GxsIdDetails::getName(const RsIdentityDetails &details)
|
QString GxsIdDetails::getName(const RsIdentityDetails &details)
|
||||||
{
|
{
|
||||||
if(details.mReputation.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( details.mReputation.mOverallReputationLevel ==
|
||||||
return tr("[Banned]") ;
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
|
return tr("[Banned]");
|
||||||
|
|
||||||
QString name = QString::fromUtf8(details.mNickname.c_str()).left(RSID_MAXIMUM_NICKNAME_SIZE);
|
QString name = QString::fromUtf8(details.mNickname.c_str()).left(RSID_MAXIMUM_NICKNAME_SIZE);
|
||||||
|
|
||||||
@ -956,7 +958,8 @@ QString GxsIdDetails::getComment(const RsIdentityDetails &details)
|
|||||||
QString comment;
|
QString comment;
|
||||||
QString nickname ;
|
QString nickname ;
|
||||||
|
|
||||||
bool banned = (details.mReputation.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE);
|
bool banned = ( details.mReputation.mOverallReputationLevel ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE );
|
||||||
|
|
||||||
if(details.mNickname.empty())
|
if(details.mNickname.empty())
|
||||||
nickname = tr("[Unknown]") ;
|
nickname = tr("[Unknown]") ;
|
||||||
@ -997,19 +1000,27 @@ QString nickname ;
|
|||||||
return comment;
|
return comment;
|
||||||
}
|
}
|
||||||
|
|
||||||
QIcon GxsIdDetails::getReputationIcon(RsReputations::ReputationLevel icon_index,uint32_t min_reputation)
|
QIcon GxsIdDetails::getReputationIcon(
|
||||||
|
RsReputationLevel icon_index, uint32_t min_reputation )
|
||||||
{
|
{
|
||||||
if( icon_index >= min_reputation ) return QIcon(REPUTATION_VOID) ;
|
if( static_cast<uint32_t>(icon_index) >= min_reputation )
|
||||||
|
return QIcon(REPUTATION_VOID);
|
||||||
|
|
||||||
switch(icon_index)
|
switch(icon_index)
|
||||||
{
|
{
|
||||||
case RsReputations::REPUTATION_LOCALLY_NEGATIVE: return QIcon(REPUTATION_LOCALLY_NEGATIVE_ICON) ; break ;
|
case RsReputationLevel::LOCALLY_NEGATIVE:
|
||||||
case RsReputations::REPUTATION_LOCALLY_POSITIVE: return QIcon(REPUTATION_LOCALLY_POSITIVE_ICON) ; break ;
|
return QIcon(REPUTATION_LOCALLY_NEGATIVE_ICON);
|
||||||
case RsReputations::REPUTATION_REMOTELY_POSITIVE: return QIcon(REPUTATION_REMOTELY_POSITIVE_ICON) ; break ;
|
case RsReputationLevel::LOCALLY_POSITIVE:
|
||||||
case RsReputations::REPUTATION_REMOTELY_NEGATIVE: return QIcon(REPUTATION_REMOTELY_NEGATIVE_ICON) ; break ;
|
return QIcon(REPUTATION_LOCALLY_POSITIVE_ICON);
|
||||||
case RsReputations::REPUTATION_NEUTRAL: return QIcon(REPUTATION_NEUTRAL_ICON) ; break ;
|
case RsReputationLevel::REMOTELY_POSITIVE:
|
||||||
default:
|
return QIcon(REPUTATION_REMOTELY_POSITIVE_ICON);
|
||||||
std::cerr << "Asked for unidentified icon index " << icon_index << std::endl;
|
case RsReputationLevel::REMOTELY_NEGATIVE:
|
||||||
|
return QIcon(REPUTATION_REMOTELY_NEGATIVE_ICON);
|
||||||
|
case RsReputationLevel::NEUTRAL:
|
||||||
|
return QIcon(REPUTATION_NEUTRAL_ICON);
|
||||||
|
default:
|
||||||
|
std::cerr << "Asked for unidentified icon index "
|
||||||
|
<< static_cast<uint32_t>(icon_index) << std::endl;
|
||||||
return QIcon(); // dont draw anything
|
return QIcon(); // dont draw anything
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1018,7 +1029,8 @@ void GxsIdDetails::getIcons(const RsIdentityDetails &details, QList<QIcon> &icon
|
|||||||
{
|
{
|
||||||
QPixmap pix ;
|
QPixmap pix ;
|
||||||
|
|
||||||
if(details.mReputation.mOverallReputationLevel == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if( details.mReputation.mOverallReputationLevel ==
|
||||||
|
RsReputationLevel::LOCALLY_NEGATIVE )
|
||||||
{
|
{
|
||||||
icons.clear() ;
|
icons.clear() ;
|
||||||
icons.push_back(QIcon(IMAGE_BANNED)) ;
|
icons.push_back(QIcon(IMAGE_BANNED)) ;
|
||||||
|
@ -49,7 +49,8 @@ typedef void (*GxsIdDetailsCallbackFunction)(GxsIdDetailsType type, const RsIden
|
|||||||
class ReputationItemDelegate: public QStyledItemDelegate
|
class ReputationItemDelegate: public QStyledItemDelegate
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ReputationItemDelegate(RsReputations::ReputationLevel max_level_to_display) : mMaxLevelToDisplay(max_level_to_display) {}
|
ReputationItemDelegate(RsReputationLevel max_level_to_display) :
|
||||||
|
mMaxLevelToDisplay(static_cast<uint32_t>(max_level_to_display)) {}
|
||||||
|
|
||||||
virtual void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const;
|
virtual void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const;
|
||||||
|
|
||||||
@ -96,7 +97,8 @@ public:
|
|||||||
static QString getNameForType(GxsIdDetailsType type, const RsIdentityDetails &details);
|
static QString getNameForType(GxsIdDetailsType type, const RsIdentityDetails &details);
|
||||||
|
|
||||||
static QIcon getLoadingIcon(const RsGxsId &id);
|
static QIcon getLoadingIcon(const RsGxsId &id);
|
||||||
static QIcon getReputationIcon(RsReputations::ReputationLevel icon_index, uint32_t min_reputation);
|
static QIcon getReputationIcon(
|
||||||
|
RsReputationLevel icon_index, uint32_t min_reputation );
|
||||||
|
|
||||||
static void GenerateCombinedPixmap(QPixmap &pixmap, const QList<QIcon> &icons, int iconSize);
|
static void GenerateCombinedPixmap(QPixmap &pixmap, const QList<QIcon> &icons, int iconSize);
|
||||||
|
|
||||||
|
@ -149,30 +149,34 @@ void GxsIdRSTreeWidgetItem::setAvatar(const RsGxsImage &avatar)
|
|||||||
|
|
||||||
QVariant GxsIdRSTreeWidgetItem::data(int column, int role) const
|
QVariant GxsIdRSTreeWidgetItem::data(int column, int role) const
|
||||||
{
|
{
|
||||||
if (column == idColumn())
|
if (column == idColumn())
|
||||||
{
|
{
|
||||||
if (role == Qt::ToolTipRole)
|
if (role == Qt::ToolTipRole)
|
||||||
{
|
{
|
||||||
QString t = RSTreeWidgetItem::data(column, role).toString();
|
QString t = RSTreeWidgetItem::data(column, role).toString();
|
||||||
QImage pix;
|
QImage pix;
|
||||||
|
|
||||||
if(mId.isNull())
|
if(mId.isNull()) return RSTreeWidgetItem::data(column, role);
|
||||||
return RSTreeWidgetItem::data(column, role);
|
else if( rsReputations->overallReputationLevel(mId) ==
|
||||||
else if(rsReputations->overallReputationLevel(mId) == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
RsReputationLevel::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 = GxsIdDetails::makeDefaultIcon(mId);
|
!pix.loadFromData(mAvatar.mData, mAvatar.mSize, "PNG") )
|
||||||
|
pix = GxsIdDetails::makeDefaultIcon(mId);
|
||||||
|
|
||||||
int S = QFontMetricsF(font(column)).height();
|
int S = QFontMetricsF(font(column)).height();
|
||||||
|
|
||||||
QString embeddedImage;
|
QString embeddedImage;
|
||||||
if (RsHtml::makeEmbeddedImage(pix.scaled(QSize(4*S,4*S), Qt::KeepAspectRatio, Qt::SmoothTransformation), embeddedImage, 8*S * 8*S)) {
|
if ( RsHtml::makeEmbeddedImage(
|
||||||
t = "<table><tr><td>" + embeddedImage + "</td><td>" + t + "</td></table>";
|
pix.scaled(QSize(4*S,4*S), Qt::KeepAspectRatio,
|
||||||
}
|
Qt::SmoothTransformation ),
|
||||||
|
embeddedImage, 8*S * 8*S ) )
|
||||||
|
t = "<table><tr><td>" + embeddedImage + "</td><td>" + t
|
||||||
|
+ "</td></table>";
|
||||||
|
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return RSTreeWidgetItem::data(column, role);
|
return RSTreeWidgetItem::data(column, role);
|
||||||
}
|
}
|
||||||
|
@ -64,7 +64,7 @@ private:
|
|||||||
bool mIdFound;
|
bool mIdFound;
|
||||||
bool mBannedState ;
|
bool mBannedState ;
|
||||||
bool mRetryWhenFailed;
|
bool mRetryWhenFailed;
|
||||||
RsReputations::ReputationLevel mReputationLevel ;
|
RsReputationLevel mReputationLevel;
|
||||||
uint32_t mIconTypeMask;
|
uint32_t mIconTypeMask;
|
||||||
RsGxsImage mAvatar;
|
RsGxsImage mAvatar;
|
||||||
};
|
};
|
||||||
|
@ -824,19 +824,20 @@ void RsGxsForumModel::convertMsgToPostEntry(const RsGxsForumGroup& mForumGroup,c
|
|||||||
void RsGxsForumModel::computeReputationLevel(uint32_t forum_sign_flags,ForumModelPostEntry& fentry)
|
void RsGxsForumModel::computeReputationLevel(uint32_t forum_sign_flags,ForumModelPostEntry& fentry)
|
||||||
{
|
{
|
||||||
uint32_t idflags =0;
|
uint32_t idflags =0;
|
||||||
RsReputations::ReputationLevel reputation_level = rsReputations->overallReputationLevel(fentry.mAuthorId,&idflags) ;
|
RsReputationLevel reputation_level =
|
||||||
|
rsReputations->overallReputationLevel(fentry.mAuthorId, &idflags);
|
||||||
bool redacted = false;
|
bool redacted = false;
|
||||||
|
|
||||||
if(reputation_level == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
if(reputation_level == RsReputationLevel::LOCALLY_NEGATIVE)
|
||||||
fentry.mPostFlags |= ForumModelPostEntry::FLAG_POST_IS_REDACTED;
|
fentry.mPostFlags |= ForumModelPostEntry::FLAG_POST_IS_REDACTED;
|
||||||
else
|
else
|
||||||
fentry.mPostFlags &= ~ForumModelPostEntry::FLAG_POST_IS_REDACTED;
|
fentry.mPostFlags &= ~ForumModelPostEntry::FLAG_POST_IS_REDACTED;
|
||||||
|
|
||||||
// We use a specific item model for forums in order to handle the post pinning.
|
// We use a specific item model for forums in order to handle the post pinning.
|
||||||
|
|
||||||
if(reputation_level == RsReputations::REPUTATION_UNKNOWN)
|
if(reputation_level == RsReputationLevel::UNKNOWN)
|
||||||
fentry.mReputationWarningLevel = 3 ;
|
fentry.mReputationWarningLevel = 3 ;
|
||||||
else if(reputation_level == RsReputations::REPUTATION_LOCALLY_NEGATIVE)
|
else if(reputation_level == RsReputationLevel::LOCALLY_NEGATIVE)
|
||||||
fentry.mReputationWarningLevel = 2 ;
|
fentry.mReputationWarningLevel = 2 ;
|
||||||
else if(reputation_level < rsGxsForums->minReputationForForwardingMessages(forum_sign_flags,idflags))
|
else if(reputation_level < rsGxsForums->minReputationForForwardingMessages(forum_sign_flags,idflags))
|
||||||
fentry.mReputationWarningLevel = 1 ;
|
fentry.mReputationWarningLevel = 1 ;
|
||||||
@ -1301,7 +1302,7 @@ void RsGxsForumModel::debug_dump()
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void RsGxsForumModel::setAuthorOpinion(const QModelIndex& indx,RsReputations::Opinion op)
|
void RsGxsForumModel::setAuthorOpinion(const QModelIndex& indx, RsOpinion op)
|
||||||
{
|
{
|
||||||
if(!indx.isValid())
|
if(!indx.isValid())
|
||||||
return ;
|
return ;
|
||||||
@ -1312,7 +1313,8 @@ void RsGxsForumModel::setAuthorOpinion(const QModelIndex& indx,RsReputations::Op
|
|||||||
if(!convertRefPointerToTabEntry(ref,entry) || entry >= mPosts.size())
|
if(!convertRefPointerToTabEntry(ref,entry) || entry >= mPosts.size())
|
||||||
return ;
|
return ;
|
||||||
|
|
||||||
std::cerr << "Setting own opinion for author " << mPosts[entry].mAuthorId << " to " << op << std::endl;
|
std::cerr << "Setting own opinion for author " << mPosts[entry].mAuthorId
|
||||||
|
<< " to " << static_cast<uint32_t>(op) << std::endl;
|
||||||
RsGxsId author_id = mPosts[entry].mAuthorId;
|
RsGxsId author_id = mPosts[entry].mAuthorId;
|
||||||
|
|
||||||
rsReputations->setOwnOpinion(author_id,op) ;
|
rsReputations->setOwnOpinion(author_id,op) ;
|
||||||
|
@ -119,7 +119,7 @@ public:
|
|||||||
|
|
||||||
void setMsgReadStatus(const QModelIndex &i, bool read_status, bool with_children);
|
void setMsgReadStatus(const QModelIndex &i, bool read_status, bool with_children);
|
||||||
void setFilter(int column, const QStringList &strings, uint32_t &count) ;
|
void setFilter(int column, const QStringList &strings, uint32_t &count) ;
|
||||||
void setAuthorOpinion(const QModelIndex& indx,RsReputations::Opinion op);
|
void setAuthorOpinion(const QModelIndex& indx,RsOpinion op);
|
||||||
|
|
||||||
int rowCount(const QModelIndex& parent = QModelIndex()) const override;
|
int rowCount(const QModelIndex& parent = QModelIndex()) const override;
|
||||||
int columnCount(const QModelIndex &parent = QModelIndex()) const override;
|
int columnCount(const QModelIndex &parent = QModelIndex()) const override;
|
||||||
|
@ -770,17 +770,17 @@ void GxsForumThreadWidget::threadListCustomPopupMenu(QPoint /*point*/)
|
|||||||
|
|
||||||
QAction *flagaspositiveAct = new QAction(QIcon(IMAGE_POSITIVE_OPINION), tr("Give positive opinion"), &contextMnu);
|
QAction *flagaspositiveAct = new QAction(QIcon(IMAGE_POSITIVE_OPINION), tr("Give positive opinion"), &contextMnu);
|
||||||
flagaspositiveAct->setToolTip(tr("This will block/hide messages from this person, and notify friend nodes.")) ;
|
flagaspositiveAct->setToolTip(tr("This will block/hide messages from this person, and notify friend nodes.")) ;
|
||||||
flagaspositiveAct->setData(RsReputations::OPINION_POSITIVE) ;
|
flagaspositiveAct->setData(static_cast<uint32_t>(RsOpinion::POSITIVE));
|
||||||
connect(flagaspositiveAct, SIGNAL(triggered()), this, SLOT(flagperson()));
|
connect(flagaspositiveAct, SIGNAL(triggered()), this, SLOT(flagperson()));
|
||||||
|
|
||||||
QAction *flagasneutralAct = new QAction(QIcon(IMAGE_NEUTRAL_OPINION), tr("Give neutral opinion"), &contextMnu);
|
QAction *flagasneutralAct = new QAction(QIcon(IMAGE_NEUTRAL_OPINION), tr("Give neutral opinion"), &contextMnu);
|
||||||
flagasneutralAct->setToolTip(tr("Doing this, you trust your friends to decide to forward this message or not.")) ;
|
flagasneutralAct->setToolTip(tr("Doing this, you trust your friends to decide to forward this message or not.")) ;
|
||||||
flagasneutralAct->setData(RsReputations::OPINION_NEUTRAL) ;
|
flagasneutralAct->setData(static_cast<uint32_t>(RsOpinion::NEUTRAL));
|
||||||
connect(flagasneutralAct, SIGNAL(triggered()), this, SLOT(flagperson()));
|
connect(flagasneutralAct, SIGNAL(triggered()), this, SLOT(flagperson()));
|
||||||
|
|
||||||
QAction *flagasnegativeAct = new QAction(QIcon(IMAGE_NEGATIVE_OPINION), tr("Give negative opinion"), &contextMnu);
|
QAction *flagasnegativeAct = new QAction(QIcon(IMAGE_NEGATIVE_OPINION), tr("Give negative opinion"), &contextMnu);
|
||||||
flagasnegativeAct->setToolTip(tr("This will block/hide messages from this person, and notify friend nodes.")) ;
|
flagasnegativeAct->setToolTip(tr("This will block/hide messages from this person, and notify friend nodes.")) ;
|
||||||
flagasnegativeAct->setData(RsReputations::OPINION_NEGATIVE) ;
|
flagasnegativeAct->setData(static_cast<uint32_t>(RsOpinion::NEGATIVE));
|
||||||
connect(flagasnegativeAct, SIGNAL(triggered()), this, SLOT(flagperson()));
|
connect(flagasnegativeAct, SIGNAL(triggered()), this, SLOT(flagperson()));
|
||||||
|
|
||||||
QAction *newthreadAct = new QAction(QIcon(IMAGE_MESSAGE), tr("Start New Thread"), &contextMnu);
|
QAction *newthreadAct = new QAction(QIcon(IMAGE_MESSAGE), tr("Start New Thread"), &contextMnu);
|
||||||
@ -876,19 +876,19 @@ void GxsForumThreadWidget::threadListCustomPopupMenu(QPoint /*point*/)
|
|||||||
#endif
|
#endif
|
||||||
contextMnu.addSeparator();
|
contextMnu.addSeparator();
|
||||||
|
|
||||||
RsReputations::Opinion op ;
|
RsOpinion op;
|
||||||
|
|
||||||
if(!rsIdentity->isOwnId(current_post.mAuthorId) && rsReputations->getOwnOpinion(current_post.mAuthorId,op))
|
if(!rsIdentity->isOwnId(current_post.mAuthorId) && rsReputations->getOwnOpinion(current_post.mAuthorId,op))
|
||||||
{
|
{
|
||||||
QMenu *submenu1 = contextMnu.addMenu(tr("Author's reputation")) ;
|
QMenu *submenu1 = contextMnu.addMenu(tr("Author's reputation")) ;
|
||||||
|
|
||||||
if(op != RsReputations::OPINION_POSITIVE)
|
if(op != RsOpinion::POSITIVE)
|
||||||
submenu1->addAction(flagaspositiveAct);
|
submenu1->addAction(flagaspositiveAct);
|
||||||
|
|
||||||
if(op != RsReputations::OPINION_NEUTRAL)
|
if(op != RsOpinion::NEUTRAL)
|
||||||
submenu1->addAction(flagasneutralAct);
|
submenu1->addAction(flagasneutralAct);
|
||||||
|
|
||||||
if(op != RsReputations::OPINION_NEGATIVE)
|
if(op != RsOpinion::NEGATIVE)
|
||||||
submenu1->addAction(flagasnegativeAct);
|
submenu1->addAction(flagasnegativeAct);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1294,8 +1294,10 @@ void GxsForumThreadWidget::insertMessageData(const RsGxsForumMsg &msg)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t overall_reputation = rsReputations->overallReputationLevel(msg.mMeta.mAuthorId) ;
|
RsReputationLevel overall_reputation =
|
||||||
bool redacted = (overall_reputation == RsReputations::REPUTATION_LOCALLY_NEGATIVE) ;
|
rsReputations->overallReputationLevel(msg.mMeta.mAuthorId);
|
||||||
|
bool redacted =
|
||||||
|
(overall_reputation == RsReputationLevel::LOCALLY_NEGATIVE);
|
||||||
|
|
||||||
#ifdef TO_REMOVE
|
#ifdef TO_REMOVE
|
||||||
bool setToReadOnActive = Settings->getForumMsgSetToReadOnActivate();
|
bool setToReadOnActive = Settings->getForumMsgSetToReadOnActivate();
|
||||||
@ -1621,9 +1623,12 @@ void GxsForumThreadWidget::flagperson()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
RsReputations::Opinion opinion = static_cast<RsReputations::Opinion>(qobject_cast<QAction*>(sender())->data().toUInt());
|
RsOpinion opinion =
|
||||||
|
static_cast<RsOpinion>(
|
||||||
|
qobject_cast<QAction*>(sender())->data().toUInt() );
|
||||||
|
|
||||||
mThreadModel->setAuthorOpinion(mThreadProxyModel->mapToSource(getCurrentIndex()),opinion);
|
mThreadModel->setAuthorOpinion(
|
||||||
|
mThreadProxyModel->mapToSource(getCurrentIndex()), opinion );
|
||||||
}
|
}
|
||||||
|
|
||||||
void GxsForumThreadWidget::replytoforummessage() { async_msg_action( &GxsForumThreadWidget::replyForumMessageData ); }
|
void GxsForumThreadWidget::replytoforummessage() { async_msg_action( &GxsForumThreadWidget::replyForumMessageData ); }
|
||||||
|
@ -38,12 +38,12 @@ PeoplePage::PeoplePage(QWidget * parent, Qt::WindowFlags flags)
|
|||||||
connect(ui.autoAddFriendIdsAsContact_CB,SIGNAL(toggled(bool)),this,SLOT(updateAutoAddFriendIdsAsContact()));
|
connect(ui.autoAddFriendIdsAsContact_CB,SIGNAL(toggled(bool)),this,SLOT(updateAutoAddFriendIdsAsContact()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void PeoplePage::updateAutoPositiveOpinion() { rsReputations->setNodeAutoPositiveOpinionForContacts(ui.autoPositiveOpinion_CB->isChecked()) ; }
|
void PeoplePage::updateAutoPositiveOpinion() { rsReputations->setAutoPositiveOpinionForContacts(ui.autoPositiveOpinion_CB->isChecked()) ; }
|
||||||
|
|
||||||
void PeoplePage::updateThresholdForRemotelyPositiveReputation() { rsReputations->setThresholdForRemotelyPositiveReputation(ui.thresholdForPositive_SB->value()); }
|
void PeoplePage::updateThresholdForRemotelyPositiveReputation() { rsReputations->setThresholdForRemotelyPositiveReputation(ui.thresholdForPositive_SB->value()); }
|
||||||
void PeoplePage::updateThresholdForRemotelyNegativeReputation() { rsReputations->setThresholdForRemotelyNegativeReputation(ui.thresholdForNegative_SB->value()); }
|
void PeoplePage::updateThresholdForRemotelyNegativeReputation() { rsReputations->setThresholdForRemotelyNegativeReputation(ui.thresholdForNegative_SB->value()); }
|
||||||
|
|
||||||
void PeoplePage::updateRememberDeletedNodes() { rsReputations->setRememberDeletedNodesThreshold(ui.preventReloadingBannedIdentitiesFor_SB->value()); }
|
void PeoplePage::updateRememberDeletedNodes() { rsReputations->setRememberBannedIdThreshold(ui.preventReloadingBannedIdentitiesFor_SB->value()); }
|
||||||
void PeoplePage::updateDeleteBannedNodesThreshold() { rsIdentity->setDeleteBannedNodesThreshold(ui.deleteBannedIdentitiesAfter_SB->value());}
|
void PeoplePage::updateDeleteBannedNodesThreshold() { rsIdentity->setDeleteBannedNodesThreshold(ui.deleteBannedIdentitiesAfter_SB->value());}
|
||||||
void PeoplePage::updateAutoAddFriendIdsAsContact() { rsIdentity->setAutoAddFriendIdsAsContact(ui.autoAddFriendIdsAsContact_CB->isChecked()) ; }
|
void PeoplePage::updateAutoAddFriendIdsAsContact() { rsIdentity->setAutoAddFriendIdsAsContact(ui.autoAddFriendIdsAsContact_CB->isChecked()) ; }
|
||||||
|
|
||||||
@ -54,7 +54,7 @@ PeoplePage::~PeoplePage()
|
|||||||
/** Loads the settings for this page */
|
/** Loads the settings for this page */
|
||||||
void PeoplePage::load()
|
void PeoplePage::load()
|
||||||
{
|
{
|
||||||
bool auto_positive_contacts = rsReputations->nodeAutoPositiveOpinionForContacts() ;
|
bool auto_positive_contacts = rsReputations->autoPositiveOpinionForContacts() ;
|
||||||
uint32_t threshold_for_positive = rsReputations->thresholdForRemotelyPositiveReputation();
|
uint32_t threshold_for_positive = rsReputations->thresholdForRemotelyPositiveReputation();
|
||||||
uint32_t threshold_for_negative = rsReputations->thresholdForRemotelyNegativeReputation();
|
uint32_t threshold_for_negative = rsReputations->thresholdForRemotelyNegativeReputation();
|
||||||
bool auto_add_friend_ids_as_contact = rsIdentity->autoAddFriendIdsAsContact();
|
bool auto_add_friend_ids_as_contact = rsIdentity->autoAddFriendIdsAsContact();
|
||||||
@ -64,5 +64,5 @@ void PeoplePage::load()
|
|||||||
whileBlocking(ui.thresholdForPositive_SB )->setValue(threshold_for_positive);
|
whileBlocking(ui.thresholdForPositive_SB )->setValue(threshold_for_positive);
|
||||||
whileBlocking(ui.thresholdForNegative_SB )->setValue(threshold_for_negative);
|
whileBlocking(ui.thresholdForNegative_SB )->setValue(threshold_for_negative);
|
||||||
whileBlocking(ui.deleteBannedIdentitiesAfter_SB )->setValue(rsIdentity->deleteBannedNodesThreshold());
|
whileBlocking(ui.deleteBannedIdentitiesAfter_SB )->setValue(rsIdentity->deleteBannedNodesThreshold());
|
||||||
whileBlocking(ui.preventReloadingBannedIdentitiesFor_SB)->setValue(rsReputations->rememberDeletedNodesThreshold());
|
whileBlocking(ui.preventReloadingBannedIdentitiesFor_SB)->setValue(rsReputations->rememberBannedIdThreshold());
|
||||||
}
|
}
|
||||||
|
@ -241,6 +241,7 @@ rs_v07_changes {
|
|||||||
DEFINES += V07_NON_BACKWARD_COMPATIBLE_CHANGE_001
|
DEFINES += V07_NON_BACKWARD_COMPATIBLE_CHANGE_001
|
||||||
DEFINES += V07_NON_BACKWARD_COMPATIBLE_CHANGE_002
|
DEFINES += V07_NON_BACKWARD_COMPATIBLE_CHANGE_002
|
||||||
DEFINES += V07_NON_BACKWARD_COMPATIBLE_CHANGE_003
|
DEFINES += V07_NON_BACKWARD_COMPATIBLE_CHANGE_003
|
||||||
|
DEFINES += V07_NON_BACKWARD_COMPATIBLE_CHANGE_UNNAMED
|
||||||
}
|
}
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
Loading…
Reference in New Issue
Block a user