/* * RetroShare Friend Server * Copyright (C) 2021-2021 retroshare team * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * * SPDX-FileCopyrightText: Retroshare Team * SPDX-License-Identifier: AGPL-3.0-or-later */ #pragma once #include "util/rsthreads.h" #include "pqi/pqistreamer.h" #include "pgp/pgphandler.h" #include "network.h" class RsFriendServerClientRemoveItem; class RsFriendServerClientPublishItem; struct PeerInfo { typedef RsPgpFingerprint PeerDistance; RsPgpFingerprint pgp_fingerprint; std::string short_certificate; rstime_t last_connection_TS; uint64_t last_nonce; std::map closest_peers; std::map have_added_this_peer; }; class FriendServer : public RsTickingThread { public: FriendServer(const std::string& base_directory,const std::string& listening_address,uint16_t listening_port); private: // overloads RsTickingThread virtual void threadTick() override; virtual void run() override; // Own algorithmics void handleClientRemove(const RsFriendServerClientRemoveItem *item); void handleClientPublish(const RsFriendServerClientPublishItem *item); // Updates for each peer in the database, the list of closest peers w.r.t. some arbitrary distance. void updateClosestPeers(const RsPeerId& pid,const RsPgpFingerprint& fpr); // removes a single peer from all lists. void removePeer(const RsPeerId& peer_id); // Adds the incoming peer data to the list of current clients and returns the std::map::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. std::map computeListOfFriendInvites(uint32_t nb_reqs_invites, const RsPeerId &pid, std::map& 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). PeerInfo::PeerDistance computePeerDistance(const RsPgpFingerprint &p1, const RsPgpFingerprint &p2); void autoWash(); void debugPrint(); // Local members FsNetworkInterface *mni; PGPHandler *mPgpHandler; std::string mBaseDirectory; RsPgpFingerprint mRandomPeerBias; std::map mCurrentClientPeers; std::string mListeningAddress; uint16_t mListeningPort; };