2012-06-07 16:43:12 -04:00
|
|
|
#ifndef RSGXSNETSERVICE_H
|
|
|
|
#define RSGXSNETSERVICE_H
|
|
|
|
|
2012-08-06 17:00:38 -04:00
|
|
|
/*
|
|
|
|
* libretroshare/src/gxs: rsgxnetservice.h
|
|
|
|
*
|
|
|
|
* Access to rs network and synchronisation service implementation
|
|
|
|
*
|
|
|
|
* Copyright 2012-2012 by Christopher Evi-Parker
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License Version 2 as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This library 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
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
|
|
* USA.
|
|
|
|
*
|
|
|
|
* Please report all bugs and problems to "retroshare@lunamutt.com".
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2012-06-07 16:43:12 -04:00
|
|
|
#include <list>
|
|
|
|
#include <queue>
|
|
|
|
|
|
|
|
#include "rsnxs.h"
|
|
|
|
#include "rsgds.h"
|
|
|
|
#include "rsnxsobserver.h"
|
2012-07-05 17:26:14 -04:00
|
|
|
#include "pqi/p3linkmgr.h"
|
2012-06-07 16:43:12 -04:00
|
|
|
#include "serialiser/rsnxsitems.h"
|
2013-06-04 17:00:43 -04:00
|
|
|
#include "rsgxsnetutils.h"
|
2012-06-07 16:43:12 -04:00
|
|
|
#include "pqi/p3cfgmgr.h"
|
2013-06-04 17:00:43 -04:00
|
|
|
#include "rsgixs.h"
|
2012-06-11 17:56:23 -04:00
|
|
|
|
2012-06-07 16:43:12 -04:00
|
|
|
/// keep track of transaction number
|
|
|
|
typedef std::map<uint32_t, NxsTransaction*> TransactionIdMap;
|
|
|
|
|
|
|
|
/// to keep track of peers active transactions
|
|
|
|
typedef std::map<std::string, TransactionIdMap > TransactionsPeerMap;
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2012-07-12 16:18:58 -04:00
|
|
|
* This class implements the RsNetWorkExchangeService
|
|
|
|
* using transactions to handle synchrnisation of Nxs items between
|
|
|
|
* peers in a network
|
2013-03-06 18:33:23 -05:00
|
|
|
* Transactions requires the maintenance of several states between peers
|
2012-07-12 16:18:58 -04:00
|
|
|
*
|
|
|
|
* Thus a data structure maintains: peers, and their active transactions
|
|
|
|
* Then for each transaction it needs to be noted if this is an outgoing or incoming transaction
|
|
|
|
* Outgoing transaction are in 3 different states:
|
|
|
|
* 1. START 2. INITIATED 3. SENDING 4. END
|
2013-03-06 18:33:23 -05:00
|
|
|
* Incoming transaction are in 3 different states
|
2012-07-12 16:18:58 -04:00
|
|
|
* 1. START 2. RECEIVING 3. END
|
2012-06-07 16:43:12 -04:00
|
|
|
*/
|
2012-07-05 17:26:14 -04:00
|
|
|
class RsGxsNetService : public RsNetworkExchangeService, public p3ThreadedService,
|
2012-06-07 16:43:12 -04:00
|
|
|
public p3Config
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2013-02-07 18:04:16 -05:00
|
|
|
static const uint32_t FRAGMENT_SIZE;
|
2012-06-07 16:43:12 -04:00
|
|
|
/*!
|
|
|
|
* only one observer is allowed
|
|
|
|
* @param servType service type
|
|
|
|
* @param gds The data service which allows read access to a service/store
|
|
|
|
* @param nxsObs observer will be notified whenever new messages/grps
|
2013-06-04 17:00:43 -04:00
|
|
|
* @param nxsObs observer will be notified whenever new messages/grps
|
2012-06-07 16:43:12 -04:00
|
|
|
* arrive
|
|
|
|
*/
|
2013-06-04 17:00:43 -04:00
|
|
|
RsGxsNetService(uint16_t servType, RsGeneralDataService* gds, RsNxsNetMgr* netMgr,
|
2013-11-03 18:46:34 -05:00
|
|
|
RsNxsObserver* nxsObs = NULL, RsGixsReputation* repuations = NULL, RsGcxs* circles = NULL, bool grpAutoSync = true);
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-07-12 16:18:58 -04:00
|
|
|
virtual ~RsGxsNetService();
|
|
|
|
|
2012-06-07 16:43:12 -04:00
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Use this to set how far back synchronisation of messages should take place
|
|
|
|
* @param age the max age a sync item can to be allowed in a synchronisation
|
|
|
|
*/
|
|
|
|
void setSyncAge(uint32_t age);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Explicitly requests all the groups contained by a peer
|
|
|
|
* Circumvents polling of peers for message
|
|
|
|
* @param peerId id of peer
|
|
|
|
*/
|
2012-06-11 17:56:23 -04:00
|
|
|
void requestGroupsOfPeer(const std::string& peerId){ return;}
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* get messages of a peer for a given group id, this circumvents the normal
|
|
|
|
* polling of peers for messages of given group id
|
|
|
|
* @param peerId Id of peer
|
|
|
|
* @param grpId id of group to request messages for
|
|
|
|
*/
|
2012-06-26 15:52:01 -04:00
|
|
|
void requestMessagesOfPeer(const std::string& peerId, const std::string& grpId){ return; }
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* pauses synchronisation of subscribed groups and request for group id
|
|
|
|
* from peers
|
|
|
|
* @param enabled set to false to disable pause, and true otherwise
|
|
|
|
*/
|
|
|
|
void pauseSynchronisation(bool enabled);
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Request for this message is sent through to peers on your network
|
|
|
|
* and how many hops from them you've indicated
|
|
|
|
* @param msgId the messages to retrieve
|
|
|
|
* @return request token to be redeemed
|
|
|
|
*/
|
2013-10-29 17:29:20 -04:00
|
|
|
int requestMsg(const RsGxsGrpMsgIdPair& msgId){ return 0;}
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Request for this group is sent through to peers on your network
|
|
|
|
* and how many hops from them you've indicated
|
|
|
|
* @param enabled set to false to disable pause, and true otherwise
|
|
|
|
* @return request token to be redeemed
|
|
|
|
*/
|
2013-10-29 17:29:20 -04:00
|
|
|
int requestGrp(const std::list<RsGxsGroupId>& grpId, const std::string& peerId);
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-07-12 16:18:58 -04:00
|
|
|
/* p3Config methods */
|
|
|
|
|
|
|
|
public:
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-07-12 16:18:58 -04:00
|
|
|
bool loadList(std::list<RsItem *>& load);
|
|
|
|
bool saveList(bool &cleanup, std::list<RsItem *>&);
|
|
|
|
RsSerialiser *setupSerialiser();
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* initiates synchronisation
|
|
|
|
*/
|
2012-06-11 17:56:23 -04:00
|
|
|
int tick();
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Processes transactions and job queue
|
|
|
|
*/
|
|
|
|
void run();
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* called when
|
|
|
|
* items are deemed to be waiting in p3Service item queue
|
|
|
|
*/
|
|
|
|
void recvNxsItemQueue();
|
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
|
|
|
|
/** S: Transaction processing **/
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
2012-06-11 17:56:23 -04:00
|
|
|
* These process transactions which are in a wait state
|
|
|
|
* Also moves transaction which have been completed to
|
|
|
|
* the completed transactions list
|
2012-06-07 16:43:12 -04:00
|
|
|
*/
|
2012-06-11 17:56:23 -04:00
|
|
|
void processTransactions();
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
2012-06-11 17:56:23 -04:00
|
|
|
* Process completed transaction, which either simply
|
|
|
|
* retires a transaction or additionally generates a response
|
|
|
|
* to the completed transaction
|
2012-06-07 16:43:12 -04:00
|
|
|
*/
|
2012-06-11 17:56:23 -04:00
|
|
|
void processCompletedTransactions();
|
|
|
|
|
2012-07-14 13:59:54 -04:00
|
|
|
/*!
|
|
|
|
* Process transaction owned/started by user
|
|
|
|
* @param tr transaction to process, ownership stays with callee
|
|
|
|
*/
|
2012-07-15 08:38:20 -04:00
|
|
|
void locked_processCompletedOutgoingTrans(NxsTransaction* tr);
|
2012-07-14 13:59:54 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Process transactions started/owned by other peers
|
|
|
|
* @param tr transaction to process, ownership stays with callee
|
|
|
|
*/
|
2012-07-15 08:38:20 -04:00
|
|
|
void locked_processCompletedIncomingTrans(NxsTransaction* tr);
|
2012-07-14 13:59:54 -04:00
|
|
|
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
2012-06-11 17:56:23 -04:00
|
|
|
* Process a transaction item, assumes a general lock
|
|
|
|
* @param item the transaction item to process
|
2012-06-07 16:43:12 -04:00
|
|
|
*/
|
2012-06-11 17:56:23 -04:00
|
|
|
bool locked_processTransac(RsNxsTransac* item);
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* This adds a transaction
|
|
|
|
* completeted transaction list
|
|
|
|
* If this is an outgoing transaction, transaction id is
|
|
|
|
* decrement
|
|
|
|
* @param trans transaction to add
|
|
|
|
*/
|
|
|
|
void locked_completeTransaction(NxsTransaction* trans);
|
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
/*!
|
|
|
|
* This retrieves a unique transaction id that
|
|
|
|
* can be used in an outgoing transaction
|
|
|
|
*/
|
2012-07-15 08:38:20 -04:00
|
|
|
uint32_t locked_getTransactionId();
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
/*!
|
|
|
|
* This attempts to push the transaction id counter back if you have
|
|
|
|
* active outgoing transactions in play
|
|
|
|
*/
|
2012-06-07 16:43:12 -04:00
|
|
|
bool attemptRecoverIds();
|
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
/*!
|
|
|
|
* The cb listener is the owner of the grps
|
|
|
|
* @param grps
|
|
|
|
*/
|
2012-07-12 16:18:58 -04:00
|
|
|
//void notifyListenerGrps(std::list<RsNxsGrp*>& grps);
|
2012-06-11 17:56:23 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* The cb listener is the owner of the msgs
|
|
|
|
* @param msgs
|
|
|
|
*/
|
2012-07-12 16:18:58 -04:00
|
|
|
//void notifyListenerMsgs(std::list<RsNxsMsg*>& msgs);
|
2012-06-11 17:56:23 -04:00
|
|
|
|
|
|
|
/*!
|
2012-07-14 13:59:54 -04:00
|
|
|
* Generates new transaction to send msg requests based on list
|
|
|
|
* of msgs received from peer stored in passed transaction
|
2012-06-11 17:56:23 -04:00
|
|
|
* @param tr transaction responsible for generating msg request
|
|
|
|
*/
|
2012-09-04 18:32:52 -04:00
|
|
|
void locked_genReqMsgTransaction(NxsTransaction* tr);
|
2012-06-11 17:56:23 -04:00
|
|
|
|
|
|
|
/*!
|
2012-07-14 13:59:54 -04:00
|
|
|
* Generates new transaction to send grp requests based on list
|
|
|
|
* of grps received from peer stored in passed transaction
|
2012-06-11 17:56:23 -04:00
|
|
|
* @param tr transaction responsible for generating grp request
|
|
|
|
*/
|
2012-09-04 18:32:52 -04:00
|
|
|
void locked_genReqGrpTransaction(NxsTransaction* tr);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Generates new transaction to send msg data based on list
|
|
|
|
* of grpids received from peer stored in passed transaction
|
|
|
|
* @param tr transaction responsible for generating grp request
|
|
|
|
*/
|
|
|
|
void locked_genSendMsgsTransaction(NxsTransaction* tr);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Generates new transaction to send grp data based on list
|
|
|
|
* of grps received from peer stored in passed transaction
|
|
|
|
* @param tr transaction responsible for generating grp request
|
|
|
|
*/
|
|
|
|
void locked_genSendGrpsTransaction(NxsTransaction* tr);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* convenience function to add a transaction to list
|
|
|
|
* @param tr transaction to add
|
|
|
|
*/
|
|
|
|
bool locked_addTransaction(NxsTransaction* tr);
|
|
|
|
|
|
|
|
void cleanTransactionItems(NxsTransaction* tr) const;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* @param tr the transaction to check for timeout
|
|
|
|
* @return false if transaction has timed out, true otherwise
|
|
|
|
*/
|
|
|
|
bool locked_checkTransacTimedOut(NxsTransaction* tr);
|
|
|
|
|
|
|
|
/** E: Transaction processing **/
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
/** S: item handlers **/
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
/*!
|
|
|
|
* This attempts handles transaction items
|
|
|
|
* ownership of item is left with callee if this method returns false
|
|
|
|
* @param item transaction item to handle
|
|
|
|
* @return false if transaction could not be handled, ownership of item is left with callee
|
|
|
|
*/
|
|
|
|
bool handleTransaction(RsNxsItem* item);
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
/*!
|
|
|
|
* Handles an nxs item for group synchronisation
|
2012-07-12 16:18:58 -04:00
|
|
|
* by startin a transaction and sending a list
|
|
|
|
* of groups held by user
|
|
|
|
* @param item contains grp sync info
|
2012-06-11 17:56:23 -04:00
|
|
|
*/
|
|
|
|
void handleRecvSyncGroup(RsNxsSyncGrp* item);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Handles an nxs item for msgs synchronisation
|
|
|
|
* @param item contaims msg sync info
|
|
|
|
*/
|
|
|
|
void handleRecvSyncMessage(RsNxsSyncMsg* item);
|
|
|
|
|
|
|
|
/** E: item handlers **/
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
|
2013-06-04 17:00:43 -04:00
|
|
|
void runVetting();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* @param peerId The peer to vet to see if they can receive this groupid
|
|
|
|
* @param grpMeta this is the meta item to determine if it can be sent to given peer
|
|
|
|
* @param toVet groupid/peer to vet are stored here if their circle id is not cached
|
|
|
|
* @return false, if you cannot send to this peer, true otherwise
|
|
|
|
*/
|
|
|
|
bool canSendGrpId(const std::string& sslId, RsGxsGrpMetaData& grpMeta, std::vector<GrpIdCircleVet>& toVet);
|
|
|
|
|
|
|
|
|
|
|
|
bool canSendMsgIds(const std::vector<RsGxsMsgMetaData*>& msgMetas, const RsGxsGrpMetaData&, const std::string& sslId);
|
|
|
|
|
|
|
|
void locked_createTransactionFromPending(MsgRespPending* grpPend);
|
|
|
|
void locked_createTransactionFromPending(GrpRespPending* msgPend);
|
|
|
|
void locked_createTransactionFromPending(GrpCircleIdRequestVetting* grpPend);
|
|
|
|
void locked_createTransactionFromPending(MsgCircleIdsRequestVetting* grpPend);
|
|
|
|
|
|
|
|
void locked_pushMsgTransactionFromList(std::list<RsNxsItem*>& reqList, const std::string& peerId, const uint32_t& transN);
|
|
|
|
void locked_pushGrpTransactionFromList(std::list<RsNxsItem*>& reqList, const std::string& peerId, const uint32_t& transN);
|
|
|
|
void locked_pushGrpRespFromList(std::list<RsNxsItem*>& respList, const std::string& peer, const uint32_t& transN);
|
|
|
|
void locked_pushMsgRespFromList(std::list<RsNxsItem*>& itemL, const std::string& sslId, const uint32_t& transN);
|
2012-07-12 16:18:58 -04:00
|
|
|
void syncWithPeers();
|
2013-06-04 17:00:43 -04:00
|
|
|
void addGroupItemToList(NxsTransaction*& tr,
|
|
|
|
const std::string& grpId, uint32_t& transN,
|
|
|
|
std::list<RsNxsItem*>& reqList);
|
|
|
|
|
|
|
|
bool locked_canReceive(const RsGxsGrpMetaData * const grpMeta, const std::string& peerId);
|
2012-07-12 16:18:58 -04:00
|
|
|
|
2013-10-29 17:29:20 -04:00
|
|
|
void processExplicitGroupRequests();
|
|
|
|
|
2012-06-07 16:43:12 -04:00
|
|
|
private:
|
|
|
|
|
2013-02-07 18:04:16 -05:00
|
|
|
typedef std::vector<RsNxsGrp*> GrpFragments;
|
|
|
|
typedef std::vector<RsNxsMsg*> MsgFragments;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Fragment a message into individual fragments which are at most 150kb
|
|
|
|
* @param msg message to fragment
|
|
|
|
* @param msgFragments fragmented message
|
|
|
|
* @return false if fragmentation fails true otherwise
|
|
|
|
*/
|
|
|
|
bool fragmentMsg(RsNxsMsg& msg, MsgFragments& msgFragments) const;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Fragment a group into individual fragments which are at most 150kb
|
|
|
|
* @param grp group to fragment
|
|
|
|
* @param grpFragments fragmented group
|
|
|
|
* @return false if fragmentation fails true other wise
|
|
|
|
*/
|
|
|
|
bool fragmentGrp(RsNxsGrp& grp, GrpFragments& grpFragments) const;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Fragment a message into individual fragments which are at most 150kb
|
|
|
|
* @param msg message to fragment
|
|
|
|
* @param msgFragments fragmented message
|
|
|
|
* @return NULL if not possible to reconstruct message from fragment,
|
|
|
|
* pointer to defragments nxs message is possible
|
|
|
|
*/
|
|
|
|
RsNxsMsg* deFragmentMsg(MsgFragments& msgFragments) const;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Fragment a group into individual fragments which are at most 150kb
|
|
|
|
* @param grp group to fragment
|
|
|
|
* @param grpFragments fragmented group
|
|
|
|
* @return NULL if not possible to reconstruct group from fragment,
|
|
|
|
* pointer to defragments nxs group is possible
|
|
|
|
*/
|
|
|
|
RsNxsGrp* deFragmentGrp(GrpFragments& grpFragments) const;
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Note that if all fragments for a message are not found then its fragments are dropped
|
|
|
|
* @param fragments message fragments which are not necessarily from the same message
|
|
|
|
* @param partFragments the partitioned fragments (into message ids)
|
|
|
|
*/
|
|
|
|
void collateMsgFragments(MsgFragments fragments, std::map<RsGxsMessageId, MsgFragments>& partFragments) const;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Note that if all fragments for a group are not found then its fragments are dropped
|
|
|
|
* @param fragments group fragments which are not necessarily from the same group
|
|
|
|
* @param partFragments the partitioned fragments (into message ids)
|
|
|
|
*/
|
|
|
|
void collateGrpFragments(GrpFragments fragments, std::map<RsGxsGroupId, GrpFragments>& partFragments) const;
|
|
|
|
private:
|
|
|
|
|
|
|
|
|
2012-06-07 16:43:12 -04:00
|
|
|
/*** transactions ***/
|
|
|
|
|
|
|
|
/// active transactions
|
2012-06-11 17:56:23 -04:00
|
|
|
TransactionsPeerMap mTransactions;
|
2012-06-07 16:43:12 -04:00
|
|
|
|
|
|
|
/// completed transactions
|
|
|
|
std::list<NxsTransaction*> mComplTransactions;
|
|
|
|
|
2012-07-12 16:18:58 -04:00
|
|
|
/// transaction id counter
|
2012-06-07 16:43:12 -04:00
|
|
|
uint32_t mTransactionN;
|
|
|
|
|
|
|
|
/*** transactions ***/
|
|
|
|
|
|
|
|
/*** synchronisation ***/
|
2012-06-11 17:56:23 -04:00
|
|
|
std::list<RsNxsSyncGrp*> mSyncGrp;
|
|
|
|
std::list<RsNxsSyncMsg*> mSyncMsg;
|
2012-06-07 16:43:12 -04:00
|
|
|
/*** synchronisation ***/
|
|
|
|
|
|
|
|
RsNxsObserver* mObserver;
|
|
|
|
RsGeneralDataService* mDataStore;
|
|
|
|
uint16_t mServType;
|
2012-07-14 13:59:54 -04:00
|
|
|
|
|
|
|
// how much time must elapse before a timeout failure
|
|
|
|
// for an active transaction
|
2012-06-11 17:56:23 -04:00
|
|
|
uint32_t mTransactionTimeOut;
|
2012-06-07 16:43:12 -04:00
|
|
|
|
2012-07-14 13:59:54 -04:00
|
|
|
|
2012-06-11 17:56:23 -04:00
|
|
|
std::string mOwnId;
|
2012-07-05 17:26:14 -04:00
|
|
|
|
|
|
|
RsNxsNetMgr* mNetMgr;
|
|
|
|
|
2012-06-07 16:43:12 -04:00
|
|
|
/// for other members save transactions
|
|
|
|
RsMutex mNxsMutex;
|
|
|
|
|
2012-07-12 16:18:58 -04:00
|
|
|
uint32_t mSyncTs;
|
2012-09-04 18:32:52 -04:00
|
|
|
|
2012-07-12 16:18:58 -04:00
|
|
|
const uint32_t mSYNC_PERIOD;
|
|
|
|
|
2013-06-04 17:00:43 -04:00
|
|
|
RsGcxs* mCircles;
|
|
|
|
RsGixsReputation* mReputations;
|
2013-11-03 18:46:34 -05:00
|
|
|
bool mGrpAutoSync;
|
2013-06-04 17:00:43 -04:00
|
|
|
|
|
|
|
// need to be verfied
|
|
|
|
std::vector<AuthorPending*> mPendingResp;
|
|
|
|
std::vector<GrpCircleVetting*> mPendingCircleVets;
|
2013-10-29 17:29:20 -04:00
|
|
|
|
|
|
|
std::map<std::string, std::list<RsGxsGroupId> > mExplicitRequest;
|
2012-06-07 16:43:12 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // RSGXSNETSERVICE_H
|