mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-03 20:01:07 -05:00
added protocol documentation in rsgxsnetservice.cc
This commit is contained in:
parent
039db26cd2
commit
16d815f891
@ -24,6 +24,171 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
//
|
||||||
|
// RsNxsItem
|
||||||
|
// |
|
||||||
|
// +-- RsNxsSyncGrp send req for group list, with time stamp of what we have
|
||||||
|
// +-- RsNxsSyncMsg
|
||||||
|
// +-- RsNxsGroupPublishKeyItem
|
||||||
|
// +-- RsNxsSyncGrpItem send individual grp info with time stamps, authors, etc.
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// tick()
|
||||||
|
// |
|
||||||
|
// +----------- sharePublishKeys()
|
||||||
|
// |
|
||||||
|
// +----------- syncWithPeers()
|
||||||
|
// | |
|
||||||
|
// | +--if AutoSync--- send global UpdateTS of each peer to itself => the peer knows the last
|
||||||
|
// | | time current peer has received an updated from himself
|
||||||
|
// | | type=RsNxsSyncGrp
|
||||||
|
// | | role: advise to request grp list for mServType
|
||||||
|
// | |
|
||||||
|
// | +--Retrive all grp Id + meta
|
||||||
|
// |
|
||||||
|
// | For each peer
|
||||||
|
// | For each grp to request
|
||||||
|
// | send RsNxsSyncMsg(ServiceType, grpId, updateTS)
|
||||||
|
// | |
|
||||||
|
// | (Only send if rand() < sendingProb()) +---comes from mClientMsgUpdateMap
|
||||||
|
// |
|
||||||
|
// +----------- recvNxsItemQueue()
|
||||||
|
// |
|
||||||
|
// +------ handleRecvPublishKeys(auto*)
|
||||||
|
// |
|
||||||
|
// |
|
||||||
|
// |
|
||||||
|
// +------ handleRecvSyncGroup( RsNxsSyncGrp*)
|
||||||
|
// | - parse all subscribed groups. For each, send a RsNxsSyncGrpItem with publish TS
|
||||||
|
// | - pack into a single RsNxsTransac item
|
||||||
|
// | |
|
||||||
|
// | +---- canSendGrpId(peer, grpMeta, toVet) // determines if put in vetting list
|
||||||
|
// | | | // or sent right away
|
||||||
|
// | | +--CIRCLES_TYPE_LOCAL------- false
|
||||||
|
// | | +--CIRCLES_TYPE_PUBLIC------ true
|
||||||
|
// | | +--CIRCLES_TYPE_EXTERNAL---- mCircles->canSend(circleId, getPgpId(peerId))
|
||||||
|
// | | +--CIRCLES_TYPE_YOUR_EYES--- internal circle stuff
|
||||||
|
// | |
|
||||||
|
// | +---- store in mPendingCircleVet ou directement locked_pushGrpRespFromList()
|
||||||
|
// |
|
||||||
|
// +------ handleRecvSyncMessage( RsNxsSyncMsg*)
|
||||||
|
// - parse msgs from group
|
||||||
|
// - send all msg IDs for this group
|
||||||
|
// data_tick()
|
||||||
|
// |
|
||||||
|
// +----------- updateServerSyncTS()
|
||||||
|
// | - retrieve all group meta data
|
||||||
|
// | - updates mServerMsgUpdateMap[grpId]=grp->mLastPostTS for all grps
|
||||||
|
// | - updates mGrpServerUpdateItem to max of all received TS
|
||||||
|
// |
|
||||||
|
// +----------- processTransactions()
|
||||||
|
// |
|
||||||
|
// +----------- processCompletedTransactions()
|
||||||
|
// | |
|
||||||
|
// | +------ locked_processCompletedIncomingTrans()
|
||||||
|
// | | |
|
||||||
|
// | | +-------- locked_genReqMsgTransaction() // request messages based on list
|
||||||
|
// | | |
|
||||||
|
// | | +-------- locked_genReqGrpTransaction() // request groups based on list
|
||||||
|
// | | |
|
||||||
|
// | | +-------- locked_genSendMsgsTransaction() // send msg list
|
||||||
|
// | | |
|
||||||
|
// | | +-------- locked_genSendGrpsTransaction() // send group list
|
||||||
|
// | |
|
||||||
|
// | +------ locked_processCompletedOutgoingTrans()
|
||||||
|
// |
|
||||||
|
// +----------- processExplicitGroupRequests()
|
||||||
|
// | - parse mExplicitRequest and for each element (containing a grpId list),
|
||||||
|
// | send the group ID (?!?!)
|
||||||
|
// |
|
||||||
|
// +----------- runVetting()
|
||||||
|
// |
|
||||||
|
// +--------- sort items from mPendingResp
|
||||||
|
// | |
|
||||||
|
// | +------ locked_createTransactionFromPending(GrpRespPending / MsgRespPending)
|
||||||
|
// | | // takes accepted transaction and adds them to the list of active trans
|
||||||
|
// |
|
||||||
|
// +--------- sort items from mPendingCircleVetting
|
||||||
|
// |
|
||||||
|
// +------ locked_createTransactionFromPending(GrpCircleIdsRequestVetting / MsgCircleIdsRequestVetting)
|
||||||
|
// // takes accepted transaction and adds them to the list of active trans
|
||||||
|
//
|
||||||
|
// Objects for time stamps
|
||||||
|
// =======================
|
||||||
|
//
|
||||||
|
// mClientGrpUpdateMap: map< RsPeerId, TimeStamp > Time stamp over all groups sent by that peer Id
|
||||||
|
// Updated in processCompletedIncomingTransaction() from Grp list trans.
|
||||||
|
//
|
||||||
|
// Used in syncWithPeers() sending in RsNxsSyncGrp once to all peers.
|
||||||
|
// Set at server to be mGrpServerUpdateItem->grpUpdateTS
|
||||||
|
//
|
||||||
|
// mClientMsgUpdateMap: map< RsPeerId, map<grpId,TimeStamp > >
|
||||||
|
//
|
||||||
|
// Last msg list modification time sent by that peer Id
|
||||||
|
// Updated in processCompletedIncomingTransaction() from Grp list trans.
|
||||||
|
// Used in syncWithPeers() sending in RsNxsSyncGrp once to all peers.
|
||||||
|
// Set at server to be mServerMsgUpdateMap[grpId]->msgUpdateTS
|
||||||
|
//
|
||||||
|
// mGrpServerUpdateItem: TimeStamp Last group modification timestamp over all groups
|
||||||
|
//
|
||||||
|
// mServerMsgUpdateMap: map< GrpId, TimeStamp > Timestamp modification for each group (time of most recent msg)
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// Group update algorithm
|
||||||
|
// ======================
|
||||||
|
//
|
||||||
|
// CLient Server
|
||||||
|
// ====== ======
|
||||||
|
//
|
||||||
|
// tick() tick()
|
||||||
|
// | |
|
||||||
|
// +---- SyncWithPeers +-- recvNxsItemQueue()
|
||||||
|
// | |
|
||||||
|
// +---------------- Send global UpdateTS of each peer to itself => the peer knows +---------> +------ handleRecvSyncGroup( RsNxsSyncGrp*)
|
||||||
|
// | the last msg sent (stored in mClientGrpUpdateMap), | | - parse all subscribed groups. For each, send a RsNxsSyncGrpItem with publish TS
|
||||||
|
// | type=RsNxsSyncGrp | | - pack into a single RsNxsTransac item
|
||||||
|
// | role: advise to request grp list for mServType -------------------+ |
|
||||||
|
// | +--> +------ handleRecvSyncMessage( RsNxsSyncMsg*)
|
||||||
|
// +---------------- Retrieve all grp Id + meta | - parse msgs from group
|
||||||
|
// | | - send all msg IDs for this group
|
||||||
|
// +-- For each peer |
|
||||||
|
// For each grp to request |
|
||||||
|
// send RsNxsSyncMsg(ServiceType, grpId, updateTS) |
|
||||||
|
// | |
|
||||||
|
// (Only send if rand() < sendingProb()) +---comes from mClientMsgUpdateMap -----+
|
||||||
|
//
|
||||||
|
// Suggestions
|
||||||
|
// ===========
|
||||||
|
// * handleRecvSyncGroup should use mit->second.mLastPost to limit the sending of already known data
|
||||||
|
// * apparently mServerMsgUpdateMap is initially empty -> by default clients will always want to receive the data.
|
||||||
|
// => new peers will always send data for each group until they get an update for that group.
|
||||||
|
// * check that there is a timestamp for unsubscribed items, otherwise we always send TS=0 and we always get them!! (in 346)
|
||||||
|
//
|
||||||
|
// -> there is not. mClientMsgUpdateMap is updated when msgs are received.
|
||||||
|
// -> 1842: leaves before asking for msg content.
|
||||||
|
//
|
||||||
|
// Proposed changes:
|
||||||
|
// - for unsubsribed groups, mClientMsgUpdateMap[peerid][grpId]=now when the group list is received => wont be asked again
|
||||||
|
// - when we subscribe, we reset the time stamp.
|
||||||
|
//
|
||||||
|
// Better change:
|
||||||
|
// - each peer sends last
|
||||||
|
//
|
||||||
|
// * the last TS method is not perfect: do new peers always receive old messages?
|
||||||
|
//
|
||||||
|
// * there's double information between mServerMsgUpdateMap first element (groupId) and second->grpId
|
||||||
|
// * processExplicitGroupRequests() seems to send the group list that it was
|
||||||
|
// asked for without further information. How is that useful???
|
||||||
|
//
|
||||||
|
// * grps without messages will never be stamped because stamp happens in genReqMsgTransaction, after checking msgListL.empty()
|
||||||
|
// Problem: without msg, we cannot know the grpId!!
|
||||||
|
//
|
||||||
|
// * what is the effect of a time shift between computers on the GXS system?
|
||||||
|
// * we should check that we never compare time stamps computed on different computers
|
||||||
|
//
|
||||||
|
// * mClientMsgUpdateMap[peerid][grpId] is only updated when new msgs are received. Up to date groups will keep asking for lists!
|
||||||
|
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
@ -67,8 +232,8 @@
|
|||||||
|
|
||||||
#if defined(NXS_NET_DEBUG_0) || defined(NXS_NET_DEBUG_1) || defined(NXS_NET_DEBUG_2) || defined(NXS_NET_DEBUG_3) || defined(NXS_NET_DEBUG_4)
|
#if defined(NXS_NET_DEBUG_0) || defined(NXS_NET_DEBUG_1) || defined(NXS_NET_DEBUG_2) || defined(NXS_NET_DEBUG_3) || defined(NXS_NET_DEBUG_4)
|
||||||
|
|
||||||
static const RsPeerId peer_to_print = RsPeerId(std::string("")) ;// use this to limit print to this peer id only, or "" for all IDs
|
static const RsPeerId peer_to_print = RsPeerId(std::string("")) ; // use this to limit print to this peer id only, or "" for all IDs
|
||||||
static const RsGxsGroupId group_id_to_print = RsGxsGroupId(std::string("")) ;// use this to allow to this group id only, or "" for all IDs
|
static const RsGxsGroupId group_id_to_print = RsGxsGroupId(std::string("")) ; // use this to allow to this group id only, or "" for all IDs
|
||||||
static const uint32_t service_to_print = 0x0215 ; // use this to allow to this service id only, or 0 for all services
|
static const uint32_t service_to_print = 0x0215 ; // use this to allow to this service id only, or 0 for all services
|
||||||
// warning. Numbers should be SERVICE IDS (see serialiser/rsserviceids.h)
|
// warning. Numbers should be SERVICE IDS (see serialiser/rsserviceids.h)
|
||||||
|
|
||||||
@ -81,7 +246,7 @@ static std::ostream& gxsnetdebug(const RsPeerId& peer_id,const RsGxsGroupId& grp
|
|||||||
if((peer_to_print.isNull() || peer_id.isNull() || peer_id == peer_to_print)
|
if((peer_to_print.isNull() || peer_id.isNull() || peer_id == peer_to_print)
|
||||||
&& (group_id_to_print.isNull() || grp_id.isNull() || grp_id == group_id_to_print)
|
&& (group_id_to_print.isNull() || grp_id.isNull() || grp_id == group_id_to_print)
|
||||||
&& (service_to_print==0 || service_type == 0 || ((service_type >> 8)&0xffff) == service_to_print))
|
&& (service_to_print==0 || service_type == 0 || ((service_type >> 8)&0xffff) == service_to_print))
|
||||||
return std::cerr ;
|
return std::cerr << time(NULL) << ": " ;
|
||||||
else
|
else
|
||||||
return null ;
|
return null ;
|
||||||
}
|
}
|
||||||
@ -2703,8 +2868,7 @@ void RsGxsNetService::handleRecvSyncGroup(RsNxsSyncGrp* item)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::map<RsGxsGroupId, RsGxsGrpMetaData*>::iterator mit =
|
std::map<RsGxsGroupId, RsGxsGrpMetaData*>::iterator mit = grp.begin();
|
||||||
grp.begin();
|
|
||||||
|
|
||||||
std::list<RsNxsItem*> itemL;
|
std::list<RsNxsItem*> itemL;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user