mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-06-19 03:49:29 -04:00
saved owner node ID in GXS reputation item
This commit is contained in:
parent
60cf2991d4
commit
c4ef4d7743
3 changed files with 101 additions and 69 deletions
|
@ -95,6 +95,7 @@ std::ostream& RsGxsReputationSetItem::print(std::ostream &out, uint16_t indent)
|
||||||
printRsItemBase(out, "RsReputationSetItem", indent);
|
printRsItemBase(out, "RsReputationSetItem", indent);
|
||||||
|
|
||||||
out << "GxsId: " << mGxsId << std::endl;
|
out << "GxsId: " << mGxsId << std::endl;
|
||||||
|
out << "Owner: " << mOwnerNodeId << std::endl;
|
||||||
out << "mOwnOpinion: " << mOwnOpinion << std::endl;
|
out << "mOwnOpinion: " << mOwnOpinion << std::endl;
|
||||||
out << "mOwnOpinionTS : " << time(NULL) - mOwnOpinionTS << " secs ago." << std::endl;
|
out << "mOwnOpinionTS : " << time(NULL) - mOwnOpinionTS << " secs ago." << std::endl;
|
||||||
out << "Opinions from neighbors: " << std::endl;
|
out << "Opinions from neighbors: " << std::endl;
|
||||||
|
@ -148,6 +149,7 @@ uint32_t RsGxsReputationSetItem::serial_size() const
|
||||||
s += 4 ; // mOwnOpinion
|
s += 4 ; // mOwnOpinion
|
||||||
s += 4 ; // mOwnOpinionTS
|
s += 4 ; // mOwnOpinionTS
|
||||||
s += 4 ; // mIdentityFlags
|
s += 4 ; // mIdentityFlags
|
||||||
|
s += mOwnerNodeId.serial_size() ;
|
||||||
|
|
||||||
s += 4 ; // mOpinions.size()
|
s += 4 ; // mOpinions.size()
|
||||||
|
|
||||||
|
@ -216,6 +218,8 @@ bool RsGxsReputationSetItem::serialise(void *data, uint32_t& pktsize) const
|
||||||
ok &= setRawUInt32(data, tlvsize, &offset, mOwnOpinion);
|
ok &= setRawUInt32(data, tlvsize, &offset, mOwnOpinion);
|
||||||
ok &= setRawUInt32(data, tlvsize, &offset, mOwnOpinionTS);
|
ok &= setRawUInt32(data, tlvsize, &offset, mOwnOpinionTS);
|
||||||
ok &= setRawUInt32(data, tlvsize, &offset, mIdentityFlags) ;
|
ok &= setRawUInt32(data, tlvsize, &offset, mIdentityFlags) ;
|
||||||
|
ok &= mOwnerNodeId.serialise(data,tlvsize,offset) ;
|
||||||
|
|
||||||
ok &= setRawUInt32(data, tlvsize, &offset, mOpinions.size());
|
ok &= setRawUInt32(data, tlvsize, &offset, mOpinions.size());
|
||||||
|
|
||||||
for(std::map<RsPeerId,uint32_t>::const_iterator it(mOpinions.begin());it!=mOpinions.end();++it)
|
for(std::map<RsPeerId,uint32_t>::const_iterator it(mOpinions.begin());it!=mOpinions.end();++it)
|
||||||
|
@ -315,10 +319,12 @@ RsGxsReputationSetItem *RsGxsReputationSerialiser::deserialiseReputationSetItem_
|
||||||
|
|
||||||
/* add mandatory parts first */
|
/* add mandatory parts first */
|
||||||
ok &= item->mGxsId.deserialise(data, tlvsize, offset) ;
|
ok &= item->mGxsId.deserialise(data, tlvsize, offset) ;
|
||||||
|
|
||||||
|
item->mOwnerNodeId.clear(); // clears up, for backward compat.
|
||||||
|
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinion);
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinion);
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinionTS);
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinionTS);
|
||||||
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->mIdentityFlags);
|
||||||
item->mIdentityFlags = REPUTATION_IDENTITY_FLAG_NEEDS_UPDATE; // special value that means please update me.
|
|
||||||
|
|
||||||
uint32_t S ;
|
uint32_t S ;
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &S);
|
ok &= getRawUInt32(data, tlvsize, &offset, &S);
|
||||||
|
@ -357,6 +363,7 @@ RsGxsReputationSetItem *RsGxsReputationSerialiser::deserialiseReputationSetItem(
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinion);
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinion);
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinionTS);
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->mOwnOpinionTS);
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &item->mIdentityFlags);
|
ok &= getRawUInt32(data, tlvsize, &offset, &item->mIdentityFlags);
|
||||||
|
ok &= item->mOwnerNodeId.deserialise(data, tlvsize, offset) ;
|
||||||
|
|
||||||
uint32_t S ;
|
uint32_t S ;
|
||||||
ok &= getRawUInt32(data, tlvsize, &offset, &S);
|
ok &= getRawUInt32(data, tlvsize, &offset, &S);
|
||||||
|
|
|
@ -33,10 +33,11 @@
|
||||||
#include "retroshare/rsgxsifacetypes.h"
|
#include "retroshare/rsgxsifacetypes.h"
|
||||||
|
|
||||||
#define RS_PKT_SUBTYPE_GXS_REPUTATION_CONFIG_ITEM 0x01
|
#define RS_PKT_SUBTYPE_GXS_REPUTATION_CONFIG_ITEM 0x01
|
||||||
#define RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM_deprecated 0x02
|
#define RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM_deprecated2 0x02
|
||||||
#define RS_PKT_SUBTYPE_GXS_REPUTATION_UPDATE_ITEM 0x03
|
#define RS_PKT_SUBTYPE_GXS_REPUTATION_UPDATE_ITEM 0x03
|
||||||
#define RS_PKT_SUBTYPE_GXS_REPUTATION_REQUEST_ITEM 0x04
|
#define RS_PKT_SUBTYPE_GXS_REPUTATION_REQUEST_ITEM 0x04
|
||||||
#define RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM 0x05
|
#define RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM_deprecated 0x05
|
||||||
|
#define RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM 0x06
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
class RsReputationItem: public RsItem
|
class RsReputationItem: public RsItem
|
||||||
|
@ -76,6 +77,28 @@ public:
|
||||||
uint32_t mLastQuery; // when we sent out.
|
uint32_t mLastQuery; // when we sent out.
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// This class should disappear. Deprecated since Aug 1, 2016. The class definition is actually not needed,
|
||||||
|
// that is why it's commented out. Kept here in order to explains how the deserialisation works.
|
||||||
|
//
|
||||||
|
// class RsGxsReputationSetItem_deprecated: public RsReputationItem
|
||||||
|
// {
|
||||||
|
// public:
|
||||||
|
// RsGxsReputationSetItem_deprecated() :RsReputationItem(RS_PKT_SUBTYPE_GXS_REPUTATION_SET_ITEM_deprecated) {}
|
||||||
|
//
|
||||||
|
// virtual ~RsGxsReputationSetItem_deprecated() {}
|
||||||
|
// virtual void clear() {}
|
||||||
|
// std::ostream &print(std::ostream &out, uint16_t indent = 0) { return out;}
|
||||||
|
//
|
||||||
|
// virtual bool serialise(void *data,uint32_t& size) const { std::cerr << "(EE) serialise attempt for a deprecated reputation item. This should not happen" << std::endl; return false ; }
|
||||||
|
// virtual uint32_t serial_size() const ;
|
||||||
|
//
|
||||||
|
// RsGxsId mGxsId;
|
||||||
|
// uint32_t mOwnOpinion;
|
||||||
|
// uint32_t mOwnOpinionTS;
|
||||||
|
// uint32_t mIdentityFlags;
|
||||||
|
// std::map<RsPeerId, uint32_t> mOpinions; // RsPeerId -> Opinion.
|
||||||
|
// };
|
||||||
|
|
||||||
class RsGxsReputationSetItem: public RsReputationItem
|
class RsGxsReputationSetItem: public RsReputationItem
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -92,9 +115,9 @@ public:
|
||||||
uint32_t mOwnOpinion;
|
uint32_t mOwnOpinion;
|
||||||
uint32_t mOwnOpinionTS;
|
uint32_t mOwnOpinionTS;
|
||||||
uint32_t mIdentityFlags ;
|
uint32_t mIdentityFlags ;
|
||||||
|
RsPgpId mOwnerNodeId;
|
||||||
std::map<RsPeerId, uint32_t> mOpinions; // RsPeerId -> Opinion.
|
std::map<RsPeerId, uint32_t> mOpinions; // RsPeerId -> Opinion.
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGxsReputationUpdateItem: public RsReputationItem
|
class RsGxsReputationUpdateItem: public RsReputationItem
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -931,6 +931,7 @@ bool p3GxsReputation::saveList(bool& cleanup, std::list<RsItem*> &savelist)
|
||||||
item->mOwnOpinion = rit->second.mOwnOpinion;
|
item->mOwnOpinion = rit->second.mOwnOpinion;
|
||||||
item->mOwnOpinionTS = rit->second.mOwnOpinionTs;
|
item->mOwnOpinionTS = rit->second.mOwnOpinionTs;
|
||||||
item->mIdentityFlags = rit->second.mIdentityFlags;
|
item->mIdentityFlags = rit->second.mIdentityFlags;
|
||||||
|
item->mOwnerNodeId = rit->second.mOwnerNode;
|
||||||
|
|
||||||
std::map<RsPeerId, RsReputations::Opinion>::iterator oit;
|
std::map<RsPeerId, RsReputations::Opinion>::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)
|
||||||
|
@ -1069,6 +1070,7 @@ bool p3GxsReputation::loadReputationSet(RsGxsReputationSetItem *item, const std:
|
||||||
|
|
||||||
reputation.mOwnOpinion = item->mOwnOpinion;
|
reputation.mOwnOpinion = item->mOwnOpinion;
|
||||||
reputation.mOwnOpinionTs = item->mOwnOpinionTS;
|
reputation.mOwnOpinionTs = item->mOwnOpinionTS;
|
||||||
|
reputation.mOwnerNode = item->mOwnerNodeId;
|
||||||
|
|
||||||
// if dropping entries has changed the score -> must update.
|
// if dropping entries has changed the score -> must update.
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue