mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-01 02:46:20 -05:00
fixed a few bugs in peer management
This commit is contained in:
parent
25ddbe099d
commit
0cf889d556
@ -82,15 +82,19 @@ void FriendServer::handleClientPublish(const RsFriendServerClientPublishItem *it
|
|||||||
|
|
||||||
RsFriendServerServerResponseItem *sr_item = new RsFriendServerServerResponseItem;
|
RsFriendServerServerResponseItem *sr_item = new RsFriendServerServerResponseItem;
|
||||||
|
|
||||||
|
std::map<RsPeerId,RsPgpFingerprint> friends;
|
||||||
sr_item->nonce = pi->second.last_nonce;
|
sr_item->nonce = pi->second.last_nonce;
|
||||||
sr_item->friend_invites = computeListOfFriendInvites(item->n_requested_friends,pi->first,pi->second.pgp_fingerprint);
|
sr_item->friend_invites = computeListOfFriendInvites(item->n_requested_friends,pi->first,friends);
|
||||||
sr_item->PeerId(item->PeerId());
|
sr_item->PeerId(item->PeerId());
|
||||||
|
|
||||||
// Update the have_added_as_friend for the list of each peer. We do that before sending because sending destroys
|
// Update the have_added_as_friend for the list of each peer. We do that before sending because sending destroys
|
||||||
// the item.
|
// the item.
|
||||||
|
|
||||||
for(auto& it:mCurrentClientPeers)
|
for(const auto& pid:friends)
|
||||||
it.second.have_added_this_peer[computePeerDistance(it.second.pgp_fingerprint,pi->second.pgp_fingerprint)] = pi->first;
|
{
|
||||||
|
auto& p(mCurrentClientPeers[pid.first]);
|
||||||
|
p.have_added_this_peer[computePeerDistance(p.pgp_fingerprint, pi->second.pgp_fingerprint)] = pi->first;
|
||||||
|
}
|
||||||
|
|
||||||
// Send the item.
|
// Send the item.
|
||||||
mni->SendItem(sr_item);
|
mni->SendItem(sr_item);
|
||||||
@ -111,23 +115,8 @@ void FriendServer::handleClientPublish(const RsFriendServerClientPublishItem *it
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::map<std::string, bool> FriendServer::computeListOfFriendInvites(uint32_t nb_reqs_invites, const RsPeerId &pid, const RsPgpFingerprint &fpr)
|
std::map<std::string, bool> FriendServer::computeListOfFriendInvites(uint32_t nb_reqs_invites, const RsPeerId &pid, std::map<RsPeerId,RsPgpFingerprint>& friends)
|
||||||
{
|
{
|
||||||
// For now, returns the first nb_reqs_invites from the currently known peer, that would not be the peer who's asking
|
|
||||||
|
|
||||||
std::map<std::string,bool> res;
|
|
||||||
|
|
||||||
for(auto it:mCurrentClientPeers)
|
|
||||||
{
|
|
||||||
if(it.first == pid)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
res.insert(std::make_pair(it.second.short_certificate,false)); // for now we say that peers havn't been warned already
|
|
||||||
|
|
||||||
if(res.size() >= nb_reqs_invites)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Strategy: we want to return the same set of friends for a given PGP profile key.
|
// Strategy: we want to return the same set of friends for a given PGP profile key.
|
||||||
// Still, using some closest distance strategy, the n-closest peers for profile A is not the
|
// Still, using some closest distance strategy, the n-closest peers for profile A is not the
|
||||||
// same set than the n-closest peers for profile B. We have multiple options:
|
// same set than the n-closest peers for profile B. We have multiple options:
|
||||||
@ -148,9 +137,32 @@ std::map<std::string, bool> FriendServer::computeListOfFriendInvites(uint32_t nb
|
|||||||
// When a peer asks for k friends, read from (2) first, then (1), until the number of collected peers
|
// When a peer asks for k friends, read from (2) first, then (1), until the number of collected peers
|
||||||
// reaches the requested value.
|
// reaches the requested value.
|
||||||
//
|
//
|
||||||
// Drawbacks: it's not clear which list of friends you're going to get eventually, but in the end the peers that will be
|
// So we choose Option 2.
|
||||||
// sent that are not in the n-closest list will need to be checked, so they will be known whatsoever.
|
|
||||||
//
|
std::map<std::string,bool> res;
|
||||||
|
|
||||||
|
auto add_from = [&res,&friends,nb_reqs_invites,this](bool added,const std::map<PeerInfo::PeerDistance,RsPeerId>& lst) -> bool
|
||||||
|
{
|
||||||
|
for(const auto& pid:lst)
|
||||||
|
{
|
||||||
|
const auto p = mCurrentClientPeers.find(pid.second);
|
||||||
|
res.insert(std::make_pair(p->second.short_certificate,added));
|
||||||
|
friends.insert(std::make_pair(p->first,p->second.pgp_fingerprint));
|
||||||
|
|
||||||
|
if(res.size() >= nb_reqs_invites)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
const auto& pinfo(mCurrentClientPeers[pid]);
|
||||||
|
|
||||||
|
// First add from peers who already added the current peer as friend, and leave if we already have enough
|
||||||
|
|
||||||
|
if(add_from(true,pinfo.have_added_this_peer))
|
||||||
|
return res;
|
||||||
|
|
||||||
|
add_from(false,pinfo.closest_peers);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
@ -207,6 +219,7 @@ std::map<RsPeerId,PeerInfo>::iterator FriendServer::handleIncomingClientData(con
|
|||||||
|
|
||||||
pi.short_certificate = short_invite_b64;
|
pi.short_certificate = short_invite_b64;
|
||||||
pi.last_connection_TS = time(nullptr);
|
pi.last_connection_TS = time(nullptr);
|
||||||
|
pi.pgp_fingerprint = fpr_test;
|
||||||
|
|
||||||
while(pi.last_nonce == 0) // reuse the same identifier (so it's not really a nonce, but it's kept secret whatsoever).
|
while(pi.last_nonce == 0) // reuse the same identifier (so it's not really a nonce, but it's kept secret whatsoever).
|
||||||
pi.last_nonce = RsRandom::random_u64();
|
pi.last_nonce = RsRandom::random_u64();
|
||||||
@ -282,6 +295,7 @@ void FriendServer::removePeer(const RsPeerId& peer_id)
|
|||||||
|
|
||||||
PeerInfo::PeerDistance FriendServer::computePeerDistance(const RsPgpFingerprint& p1,const RsPgpFingerprint& p2)
|
PeerInfo::PeerDistance FriendServer::computePeerDistance(const RsPgpFingerprint& p1,const RsPgpFingerprint& p2)
|
||||||
{
|
{
|
||||||
|
std::cerr << "Computing peer distance: p1=" << p1 << " p2=" << p2 << " p1^p2=" << (p1^p2) << " distance=" << ((p1^p2)^mRandomPeerBias) << std::endl;
|
||||||
return (p1 ^ p2)^mRandomPeerBias;
|
return (p1 ^ p2)^mRandomPeerBias;
|
||||||
}
|
}
|
||||||
FriendServer::FriendServer(const std::string& base_dir)
|
FriendServer::FriendServer(const std::string& base_dir)
|
||||||
@ -337,6 +351,7 @@ void FriendServer::autoWash()
|
|||||||
void FriendServer::updateClosestPeers(const RsPeerId& pid,const RsPgpFingerprint& fpr)
|
void FriendServer::updateClosestPeers(const RsPeerId& pid,const RsPgpFingerprint& fpr)
|
||||||
{
|
{
|
||||||
for(auto& it:mCurrentClientPeers)
|
for(auto& it:mCurrentClientPeers)
|
||||||
|
if(it.first != pid)
|
||||||
{
|
{
|
||||||
PeerInfo::PeerDistance d = computePeerDistance(fpr,it.second.pgp_fingerprint);
|
PeerInfo::PeerDistance d = computePeerDistance(fpr,it.second.pgp_fingerprint);
|
||||||
|
|
||||||
@ -360,10 +375,16 @@ void FriendServer::debugPrint()
|
|||||||
|
|
||||||
for(const auto& it:mCurrentClientPeers)
|
for(const auto& it:mCurrentClientPeers)
|
||||||
{
|
{
|
||||||
RsDbg() << " " << it.first << ": nonce=" << std::hex << it.second.last_nonce << std::dec << ", last contact: " << now - it.second.last_connection_TS << " secs ago.";
|
RsDbg() << " " << it.first << ": nonce=" << std::hex << it.second.last_nonce << std::dec << " fpr: " << it.second.pgp_fingerprint << ", last contact: " << now - it.second.last_connection_TS << " secs ago.";
|
||||||
|
RsDbg() << " Closest peers:" ;
|
||||||
|
|
||||||
for(const auto& pit:it.second.closest_peers)
|
for(const auto& pit:it.second.closest_peers)
|
||||||
RsDbg() << " " << pit.second << " distance=" << pit.first ;
|
RsDbg() << " " << pit.second << " distance=" << pit.first ;
|
||||||
|
|
||||||
|
RsDbg() << " Have added this peer:" ;
|
||||||
|
|
||||||
|
for(const auto& pit:it.second.have_added_this_peer)
|
||||||
|
RsDbg() << " " << pit.second << " distance=" << pit.first ;
|
||||||
}
|
}
|
||||||
|
|
||||||
RsDbg() << "===============================================";
|
RsDbg() << "===============================================";
|
||||||
|
@ -69,7 +69,7 @@ private:
|
|||||||
std::map<RsPeerId,PeerInfo>::iterator handleIncomingClientData(const std::string& pgp_public_key_b64,const std::string& short_invite_b64);
|
std::map<RsPeerId,PeerInfo>::iterator handleIncomingClientData(const std::string& pgp_public_key_b64,const std::string& short_invite_b64);
|
||||||
|
|
||||||
// Computes the appropriate list of short invites to send to a given peer.
|
// Computes the appropriate list of short invites to send to a given peer.
|
||||||
std::map<std::string,bool> computeListOfFriendInvites(uint32_t nb_reqs_invites,const RsPeerId& pid,const RsPgpFingerprint& fpr);
|
std::map<std::string, bool> computeListOfFriendInvites(uint32_t nb_reqs_invites, const RsPeerId &pid, std::map<RsPeerId,RsPgpFingerprint>& friends);
|
||||||
|
|
||||||
// Compute the distance between peers using the random bias (It's not really a distance though. I'm not sure about the triangular inequality).
|
// Compute the distance between peers using the random bias (It's not really a distance though. I'm not sure about the triangular inequality).
|
||||||
PeerInfo::PeerDistance computePeerDistance(const RsPgpFingerprint &p1, const RsPgpFingerprint &p2);
|
PeerInfo::PeerDistance computePeerDistance(const RsPgpFingerprint &p1, const RsPgpFingerprint &p2);
|
||||||
|
Loading…
Reference in New Issue
Block a user